?第一次写文章,最近在准备pat乙级考试,分享一下最近写过的题目,相互学习,不足的地方希望大佬指出。
上正文:?
本题的关键在于E后面的数字是正还是负,正的情况下主要考虑的是什么情况下打小数点,如果E后面的数字超出了前面的长度就不输出小数点,如果小于长度就找地方输出小数点。负的情况下,就是打几个零的问题。(上代码)
#include "stdio.h"
int main()
{
char head=getchar();
char num[10000];
char ch=getchar();//获取符号位
int i=0,N=0;
while(ch!='E')//输入数字位
{
if(ch!='.')//不读入小数点
num[i++]=ch;
ch=getchar();
}
char head1=getchar();//输出零的操作情况
scanf("%d",&N);
if(head=='-')
printf("-");
if(head1=='+')//E后的符号为‘+‘
{
for(int j=0;j<i;j++)
{
printf("%c",num[j]);
if(N<(i-1))
{
if(j==N)
printf(".");
}
}
if(N>(i-1))///判断要求增加的长度与小数点后的长度大小。用于通过测试点6
{
N-=(i-1);
for(int j=0;j<N;j++)
{
printf("0");
}
}
}
else//E后的符号为‘-‘
{
for(int k=0;k<N;k++)
{
printf("0");
if(k==0)
printf(".");
}
printf("%s",num);//前面输出零了后直接把后面的字符串打印出来就好。
}
}
测试点6的情况是如果E后的符号为+,且要求增加的位数小于小数点后面的长度
例如:+1.200000000E+1
要求输出的就是12.00000000注意小数点的位置,还有就是刚好在最后一位时不输出小数点。
参考别人代码在输入的改进
char num[10000];
int N=0,d,length=0;
scanf("%d.%[0-9]E%d",&d,num,&N);
这种方法就可以不用遍历读取字符串,并且忽视掉小数点和E,直接输出,太妙了。
同时对于以后在面对特殊字符串的输入问题时,比如前面一串是小写,后面是大写,不用for加if判断
直接
char num[10000];
scanf("%[A-Z]",num);
就好了。
|