hud 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
 
//第一次提交,wa了,可能出入不是小数,找不到‘.'吧;
#include <iostream>
#include <cstring>
using namespace std; int main()
{
int n,t;
char x[];
cin>>t;
while(t--)
{
cin>>x>>n;
for(int i=;i<strlen(x);i++)
{
if(x[i]=='.')
{cout<<x[i+n]<<endl;
break;}
}
}
return ;
}

//之后的正确代码文章来源地址https://www.yii666.com/article/764022.html文章地址https://www.yii666.com/article/764022.html网址:yii666.com<网址:yii666.com文章来源地址:https://www.yii666.com/article/764022.html

#include <iostream>
#include <cstring>
using namespace std; int main()
{
int n,t,k;
char x[];
cin>>t;
while(t--)
{
cin>>x>>n;
k=-;//位置初始化,有可能找不到小数点所以是-1
for(int i=;i<strlen(x);i++)
{
if(x[i]=='.')//找到小数点;
k=i;//记录小数点的位置;
}
if(k+n<strlen(x)&&k!=-)//有小数点同时有这个数
cout<<x[k+n]<<endl;
if(k==-||k+n>=strlen(x))//没有小数点,或者要输出的位数大于输入的值
cout<<""<<endl; }
return ;
}

版权声明:本文内容来源于网络,版权归原作者所有,此博客不拥有其著作权,亦不承担相应法律责任。文本页已经标记具体来源原文地址,请点击原文查看来源网址,站内文章以及资源内容站长不承诺其正确性,如侵犯了您的权益,请联系站长如有侵权请联系站长,将立刻删除

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信图片_20190322181744_03.jpg

微信扫一扫打赏

请作者喝杯咖啡吧~

支付宝扫一扫领取红包,优惠每天领

二维码1

zhifubaohongbao.png

二维码2

zhifubaohongbao2.png