首页 > 其他 > 详细

POJ 1001 Exponentiation(大数处理)

时间:2014-03-14 11:01:25      阅读:435      评论:0      收藏:0      [点我收藏+]

http://poj.org/problem?id=1001


题意:给你一个浮点数,一个整数,求浮点数的整数次方。


思路:大数解决,注意处理后面多余的零跟前面多余的零,以及Java科学计数法的问题。


import java.math.*;
import java.util.Scanner;

public class Main {	
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		/*sss*/
		BigDecimal a, c, d;
		int b ;
		Scanner cin = new Scanner(System.in);
		while(cin.hasNext()){
			a = cin.nextBigDecimal();
			b = cin.nextInt();
			a = a.pow(b);
			String s;
			s = a.toPlainString();  //避免科学记数法(如果用a.toSting会存成科学记数法)
			int start = 0;
			while(s.charAt(start) == ‘0‘){   //a.charAt(b) 取a字符串下标为b的字符
				start++;
			}
			int end = s.length()-1;
			while(s.charAt(end) == ‘0‘){
				end--;
			}
			if(s.charAt(end) == ‘.‘){
				end--;
			}
			for(int i = start; i <= end; ++i){
				System.out.print(s.charAt(i));
			}
			System.out.println();
			
			//System.out.println();//subtract-, add+, multiply* divide/ 
		}
		cin.close();
	}	
}


POJ 1001 Exponentiation(大数处理),布布扣,bubuko.com

POJ 1001 Exponentiation(大数处理)

原文:http://blog.csdn.net/xuechelingxiao/article/details/21196569

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!