HDU2549 壮志难酬【水题】

壮志难酬

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 8807    Accepted Submission(s): 2905

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
 
Author
英雄哪里出来
 
Source

2008“缤纷下沙校园文化活动月”之大学生程序设计竞赛暨新生专场


题目大意:给你一个小数(肯定有小数点),和一个整数N,求小数点后第N位是多少。

思路:直接用字符串存储小数,找到小数点的位置。然后先判断小数点后够不够N位,够N

位就输出小数点后第N位上的字符,否则输出"0"。

举个例子说明下:1.2 3    实际上是1.2000 3 小数点后第3位原本没有,所以用0补齐。


#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
using namespace std;

char s[11];
int main()
{
    int T,N;
    cin >> T;
    while(T--)
    {
        cin >> s >> N;
        int pos,len;
        len = strlen(s);
        for(pos = 0; pos < len; ++pos)
        {
            if(s[pos] == '.')
                break;
        }
        int sum = 0;
        for(int i = pos+1;i < len; ++i)
            sum++;
        if(sum >= N)
            cout << s[pos+N] << endl;
        else
            cout << 0 << endl;
    }

    return 0;
}


你可能感兴趣的:(HDU2549 壮志难酬【水题】)