BigDecimal再次应用——大整数相加

7-3 jmu-Java-02基本语法-07-大整数相加 (4 分)

有若干大整数,需要对其进行求和操作。

输入格式

每行输入一个字符串代表一个大整数,连续输入若干行,当某行字符为eE时退出。

输入样例:

 
  

输出样例:

 
  

分析:这里就又用到了BigDecimal类,BigDecimal类之前已经做过了一些介绍,这里就不再赘述。这个题目是大数相加,也就是说,当我们需要计算一个非常大的数字时,如果这个数字已经超越了最长的浮点型,此时我们应该怎么办,在竞赛题中我曾经使用字符串扫描的方法,通过模拟真实的计算过程来解决这个问题,而这个方法在java中就被集成到了一个类中,即BigDecimal类里,这个类的add方法就可以通过字符串处理方法,来计算这个大数或者一个定点小数。

import java.util.*;
import java.math.*;//必须导入math库


class Main {
	public static void main(String[] args) {
		Scanner s = new Scanner(System.in);
		
		String ss,aa;
		ss = s.nextLine();
		//if(ss.indexOf("e")>=0||ss.indexOf("E")>=0)
			//return;
		BigDecimal s1 = new BigDecimal(ss);//将已经输入好的ss字符串转变成BigDecimal类型
		//BigDecimal a1;
		while(true)//按题目要求进行循环
		{
			aa = s.nextLine();
			if(aa.indexOf("e")>=0||aa.indexOf("E")>=0)//判断是否有e存在,如果存在则终止
				break;
			else{
			BigDecimal a1 = new BigDecimal(aa);
			s1 = s1.add(a1);
			}
		}
		System.out.print(s1);
		
	}
}

总结:这个题的题目要求有些难懂,说实话题出的不是特别好,主要是侧重使用BigDecimal方法,而这里的具体题目要求是先输入一个大数,然后再输入第二个,第三个...,这些数要循环相加,而不是两个一组的相加,同时第一个必须输入,直接输入终止符‘e’也不会停止,这里是题目本身的问题,这里不再深究。这里在进行判别终止符时用到了一个方法是indexOf方法,这是String类的一个方法,用于查找指定字符的位置,如果找到,则返回它的位置,如果找不到,则返回-1,所以这里使用"if(aa.indexOf("e")>=0"的语句方式来判断是否串中存在它。

你可能感兴趣的:(JAVA,习题)