HDU2549:壮志难酬

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

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

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

Input
首先输入一个t,表示有t组数据,跟着t行:
每行输入一个小数(输入数据保证一定是a.b的形式,为了简单化问题,没有循环小数的情况)
然后跟一个n,表示小数点后第几位
 

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

Sample Input
31.234 12.345 23.456 3
 

Sample Output
246
 


//题目本身不难,但是又陷阱,我很不幸的没有考虑全,因为输入的数可能会不含小数,而且求的小数位可能比实际要长= =

#include <stdio.h>#include <string.h>int main(){    int n,m,len,flag,i;    char str[100];    scanf("%d%*c",&n);    while(n--)    {        scanf("%s%d",str,&m);        len = strlen(str);        if(!strstr(str,"."))//如果不含小数,即后面小数全是0        {            printf("0\n");            continue;        }        for(i = 0;i<=len;i++)//找到小数点        {            if(str[i] == '.')            break;        }        if(m>len-i-1)//判断要求的位是否比有效小数长        printf("0\n");        else//输出小数        printf("%c\n",str[i+m]);    }    return 0;}

原创粉丝点击