7-38 jmu-Java-01入门-取数字 (40 分)

7-38 jmu-Java-01入门-取数字 (40 分)

本题目要求读入若干个代表整数的字符串,然后将其转化为整数。

如果该数>=10000且<=20000,则依次输出其对应的二进制字符串、八进制字符串、十六进制字符串。

否则将字符串中的每个数字抽取出来,然后将所有数字加总求和。

提示:参考jdk文档的Integer,

输入样例:

123
10000
-123
314159265

输出样例:

1 2 3 6
10011100010000,23420,2710
1 2 3 6
3 1 4 1 5 9 2 6 5 36

思路:

这道题的考点就是进制转换,而java在这方面优势很大,都有封装好的函数,都在Integer下

还有就是对一个整数的每一位求和,这没啥说的

此外的话要注意对于负号的处理,仔细看代码

答案: 

import java.util.*;
public class Main {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner sc = new Scanner(System.in);
		String s;
		while(true)
		{
			s = sc.nextLine();
			//输入为空就跳出循环
			if(s == null)
				break;
			int m = Integer.parseInt(s);
			//如果输入是负的
			if(m<0)
				m = -m;
			//System.out.println(m);
			if(m>=10000&&m<=20000)
			{
				//要学会java内置的进制转化函数(Integer下的)
				System.out.println(Integer.toBinaryString(m)+","+Integer.toOctalString(m)+","+Integer.toHexString(m));
			}
			else
			{
				StringBuilder ss = new StringBuilder(s);
				int sum = 0;
				for(int i = 0;i < ss.length();i++)
				{
					//遇到负号直接跳过去不读
					if(s.charAt(i)=='-')
					{
						continue;
					}
					System.out.print(ss.charAt(i)+" ");
				}
				//统计求和
				while(m!=0)
				{
					int i;
					i = m%10;
					sum += i;
					m = m/10;
				}
				System.out.println(sum);
			}	
		}
		sc.close();
	}
}

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值