(hdu 2.3.2)Exponentiation(大数:求R的n次幂)
2015-02-03 11:10
295 查看
在写题解之前给自己打一下广告哈~
。。抱歉了,希望大家多多支持我在CSDN的视频课程,地址如下: http://edu.csdn.net/course/detail/209
题目:
题目分析:
简单题。大数的基本使用。求R的n次幂。
代码如下:
import java.math.BigDecimal;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
while(scanner.hasNext()){
BigDecimal r = scanner.nextBigDecimal();//对于求R^n的这种大数题。r要以BigDecimal的形式读进来.否则会出现各种各样的问题
int n = scanner.nextInt();
r = r.pow(n);
/**
* stripTrailingZeros(): 去掉末尾无效0
* toPlainString(): 由科学计数法转为普通的计数法
* 如将给一个字符串1.238761976E-10
* 转化成0.0000000001238761976
*/
String result = r.stripTrailingZeros().toPlainString();
if(result.startsWith("0.")){//用于处理0.XXX情况
result = result.substring(1);
}
System.out.println(result);
}
}
}
。。抱歉了,希望大家多多支持我在CSDN的视频课程,地址如下: http://edu.csdn.net/course/detail/209
题目:
Exponentiation |
Time Limit: 1000/500 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) |
Total Submission(s): 1938 Accepted Submission(s): 527 |
[align=left]Problem Description[/align]Problems involving the computation of exact values of very large magnitude and precision are common. For example, the computation of the national debt is a taxing experience for many computer systems. This problem requires that you write a program to compute the exact value of Rn where R is a real number ( 0.0 < R < 99.999 ) and n is an integer such that 0 < n <= 25. |
[align=left]Input[/align]The input will consist of a set of pairs of values for R and n. The R value will occupy columns 1 through 6, and the n value will be in columns 8 and 9. |
[align=left]Output[/align]The output will consist of one line for each line of input giving the exact value of R^n. Leading zeros should be suppressed in the output. Insignificant trailing zeros must not be printed. Don't print the decimal point if the result is an integer. |
[align=left]Sample Input[/align]95.123 12 0.4321 20 5.1234 15 6.7592 9 98.999 10 1.0100 12 |
[align=left]Sample Output[/align]548815620517731830194541.899025343415715973535967221869852721 .00000005148554641076956121994511276767154838481760200726351203835429763013462401 43992025569.928573701266488041146654993318703707511666295476720493953024 29448126.764121021618164430206909037173276672 90429072743629540498.107596019456651774561044010001 1.126825030131969720661201 |
[align=left]Source[/align]East Central North America 1988 |
[align=left]Recommend[/align]PrincetonBoy |
简单题。大数的基本使用。求R的n次幂。
代码如下:
import java.math.BigDecimal;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
while(scanner.hasNext()){
BigDecimal r = scanner.nextBigDecimal();//对于求R^n的这种大数题。r要以BigDecimal的形式读进来.否则会出现各种各样的问题
int n = scanner.nextInt();
r = r.pow(n);
/**
* stripTrailingZeros(): 去掉末尾无效0
* toPlainString(): 由科学计数法转为普通的计数法
* 如将给一个字符串1.238761976E-10
* 转化成0.0000000001238761976
*/
String result = r.stripTrailingZeros().toPlainString();
if(result.startsWith("0.")){//用于处理0.XXX情况
result = result.substring(1);
}
System.out.println(result);
}
}
}
相关文章推荐
- hdu 1063 Exponentiation 大数乘法
- hdu 1063 Exponentiation(大数模版题)
- HDU 1063 Exponentiation(大数乘法)
- HDU 1063Exponentiation(Java的大数处理)
- HDU 1063 && POJ 1001 Exponentiation (JAVA浮点数大数)
- hdu 1063 Exponentiation(大数)
- hdu_1063,poj_1001_Exponentiation(大数,高精度) nyoj_155_求高精度幂
- hdu 1063(求a的n次幂——大数运算)
- hdu-1063 Exponentiation大数问题
- HDU_1063_Exponentiation_大数
- HDU 3864 D_num (pollard_rho大数素数分解)
- hdu 5718(Oracle)大数加法
- HDU 5475 An easy problem(用大数模板,你就上当了)——2015 ACM/ICPC Asia Regional Shanghai Online
- 杭电HDU1002(大数加法)
- HDU 1625 Censored! (AC自动机 + 大数 + dp)
- HDU-5050 java大数
- hdu 1002大数加法
- hdu 1402-傅里叶_大数相乘
- HDU 2448 Mining Station on the Sea(最小费用流+spfa,超了n次的题)
- HDU 1047 Integer Inquiry 大数相加 string解法