HDU 2549 壮志难酬

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/changjiale110/article/details/79475382

壮志难酬

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

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

wa了一次, 也是踩到了 整个题唯一的坑货, 如果你想要的小数点后 的第n位 如果大于已有小数点后实际位数, 则是0
例如 1. 3 5 –> 1.3的小数点后5位 那么1.3变相就是 1.30000

code:

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

int main()
{
    int N;
    scanf("%d",&N);
    while (N--)
    {
        char a[100];
        getchar();
        scanf ("%s",a);
        int m;
        scanf("%d",&m);
        int n = strlen(a);
        int sum=0;
        int flag=0;
        for (int i=0; i<n; i++)
        {
            if (a[i]!='.'&&flag==1)
            {
                sum++;
                if (sum==m)
                {
                    printf ("%c\n",a[i]);
                    break;
                }

            }
            else if (a[i]=='.')
            {
                flag=1;
                continue;
            }
            else
                continue;
        }
        if (sum<m)
            printf ("0\n");

    }
}

猜你喜欢

转载自blog.csdn.net/changjiale110/article/details/79475382
hdu