HDOJ/HDU 2549 壮志难酬(取小数点后几位~)

简介: HDOJ/HDU 2549 壮志难酬(取小数点后几位~)

Problem Description

话说MCA山上各路豪杰均出山抗敌,去年曾在江湖威名显赫的,江湖人称<万军中取上将首级舍我其谁>的甘露也不甘示弱,“天将降大任于斯人也,必先劳其筋骨,饿其体肤,空乏其身”他说。可惜,由于去年取上将首级时不慎右手右关节第七次骨折,养伤达一年之久,空有一腔抱负却壮志难酬,如今天下危亡,习武之人又怎能袖手旁观,于是他决定出山协助威士忌共抗辽贼,这时他的对头枫冰叶子出现,两人都是水属性,但由于十年前的一场恩怨(这是后话)势成水火。


枫冰叶子要求甘露回答一个问题,否则不让他离开,可惜甘露绞尽脑汁未果,希望你来帮他解决,助他完成大业。


问题是这样的:给你一个小数x,让你算出小数点后第n位是什么,(1 <= n <= 6)


Input

首先输入一个t,表示有t组数据,跟着t行:

每行输入一个小数(输入数据保证一定是a.b的形式,为了简单化问题,没有循环小数的情况)

然后跟一个n,表示小数点后第几位


Output

输出一个数表示小数点后第n位的数


Sample Input

3

1.234 1

2.345 2

3.456 3


Sample Output

2

4

6


可以用Java大数,也可以用字符串处理~

但是不能用double~因为double型数据在内存中的存储不是精确的,总是接近这个数,但不等于这个数。

import java.math.BigDecimal;
import java.util.Scanner;
/**
 * @author 陈浩翔
 *
 * 2016-5-16
 */
public class Main{
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int t =sc.nextInt();
        while(t-->0){
            //因为double型数据在内存中的存储不是精确的,总是接近这个数,但不等于这个数。
            //double n = sc.nextDouble();//所以不能用double
            BigDecimal n = sc.nextBigDecimal();
            int m = sc.nextInt();
            n = n.scaleByPowerOfTen(m);
            System.out.println(n.remainder(new BigDecimal(10)).intValue());
        }
    }
}
目录
相关文章
HDOJ 2099 整除的尾数
HDOJ 2099 整除的尾数
88 0
HDOJ/HDU 2561 第二小整数(水题~排序~)
HDOJ/HDU 2561 第二小整数(水题~排序~)
118 0
|
测试技术
HDOJ(HDU) 1860 统计字符
HDOJ(HDU) 1860 统计字符
105 0
HDOJ/HDU 2352 Verdis Quo(罗马数字与10进制数的转换)
HDOJ/HDU 2352 Verdis Quo(罗马数字与10进制数的转换)
180 0
HDOJ(HDU) 2520 我是菜鸟,我怕谁(等差数列)
HDOJ(HDU) 2520 我是菜鸟,我怕谁(等差数列)
113 0
|
测试技术
HDOJ(HDU) 1859 最小长方形(水题、、)
HDOJ(HDU) 1859 最小长方形(水题、、)
81 0
|
测试技术
HDOJ 1108 最小公倍数
HDOJ 1108 最小公倍数
101 0
HDOJ 2009 求数列的和
HDOJ 2009 求数列的和
142 0
|
Java 人工智能
HDU 2561 第二小整数
第二小整数 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 10766    Accepted Submission(s): 6548 Problem Description 求n个整数中倒数第二小的数。
950 0