壮志难酬
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 4796 Accepted Submission(s): 1502
Problem Description
话说MCA山上各路豪杰均出山抗敌,去年曾在江湖威名显赫的,江湖人称<万军中取上将首级舍我其谁>的甘露也不甘示弱,“天将降大任于斯人也,必先劳其筋骨,饿其体肤,空乏其身”他说。可惜,由于去年取上将首级时不慎右手右关节第七次骨折,养伤达一年之久,空有一腔抱负却壮志难酬,如今天下危亡,习武之人又怎能袖手旁观,于是他决定出山协助威士忌共抗辽贼,这时他的对头枫冰叶子出现,两人都是水属性,但由于十年前的一场恩怨(这是后话)势成水火。
枫冰叶子要求甘露回答一个问题,否则不让他离开,可惜甘露绞尽脑汁未果,希望你来帮他解决,助他完成大业。
问题是这样的:给你一个小数x,让你算出小数点后第n位是什么,(1 <= n <= 6)
枫冰叶子要求甘露回答一个问题,否则不让他离开,可惜甘露绞尽脑汁未果,希望你来帮他解决,助他完成大业。
问题是这样的:给你一个小数x,让你算出小数点后第n位是什么,(1 <= n <= 6)
Input
首先输入一个t,表示有t组数据,跟着t行:
每行输入一个小数(输入数据保证一定是a.b的形式,为了简单化问题,没有循环小数的情况)
然后跟一个n,表示小数点后第几位
每行输入一个小数(输入数据保证一定是a.b的形式,为了简单化问题,没有循环小数的情况)
然后跟一个n,表示小数点后第几位
Output
输出一个数表示小数点后第n位的数
Sample Input
3 1.234 1 2.345 2 3.456 3
Sample Output
2 4 6
思路:这题主要考虑的是数的位数,所以选用字符串。另外注意,当给出的数据小数点位数少于所要求的位数,应当输出0;举例:1.234 6 答案:为0;还有小数点之前不只一位的数。
AC代码:
#include<iostream>
#include<string.h>
using namespace std;
int main()
{
int t,b,i,j,k,f;
char a[10000];
while(scanf("%d",&t)!=EOF)
{
while(t--)
{
scanf("%s%d",a,&b);
f=0;
for(i=0;a[i]!='\0';i++) if(a[i]=='.')break;
for(j=i+1,k=1;a[j]!='\0';j++,k++)
if(k==b){f=1;break;}
if(f==0)printf("0\n");
else cout<<a[j]<<endl;
}
}
return 0;
}