这个题真是学到了,先放一个自己的写法
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
int main(){
char a[10000],*prime;
scanf("%s",a);
if(a[0]=='-') //先打印一下符号
printf("-");
char *token=strtok(a+1,"E"); //strtok字符串分割函数,这里我就是想把小数和指数部分分割开来
prime=(char *)malloc(sizeof(char)*strlen(token)); //先给prime分配一下空间
strcpy(prime,token); //让prime指向小数部分
token=strtok(NULL,"E"); //token此时指向指数部分
int index=atoi(token); //index就是指数部分的数字,atoi是字符串转数字的函数
if(index<0) //如果指数是负的
{
index=(-index)-1; //先把指数变正方便操作
printf("0."); //肯定是0.xxxx型的
while(index--) //这里就相当于移动小数点了
printf("0");
for(int i=0;prime[i];i++) //然后打印小数部分的数字就行了
if(prime[i]!='.') //要排除.
printf("%c",prime[i]);
}
else if(index>=0) //如果指针是非负的
{
for(int i=0;prime[i]&&i<index+2;i++) //先打印小数点之前的数字,比如+1.2345E+3在这里就会输出1234
if(prime[i]!='.')
printf("%c",prime[i]);
int judge=0;
for(int i=0;i<(int)(index-strlen(prime)+2);i++){ //如果指数够大比如+1.23E+5就得输出123000了,所以需要打印0 这个为什么要加一个int强制转换类型后面再说
judge=1; //判断它是不是这种指数够大的
printf("0");
}
if(judge==0&&(index-strlen(prime)+2)){ //如果指数不够大 判断(index-strlen(prime)+2)是为了防止+1.2E+1这样的输出12.
printf("."); //先打印一个小数点
printf("%s",prime+index+2); //再打印后面的数字
}
}
return 0;
}
后面学习了别人的方法,发现居然可以这样输入!
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
int main(){
char a[10000];
int index;
scanf("%[^E]E%d",a,&index); //这样的输入方式就可以直接把小数和指数部分分开了,我只能说学到了
if(a[0]=='-')
printf("-");
char *prime=a+1;
if(index<0)
{
index=(-index)-1;
printf("0.");
while(index--)
printf("0");
for(int i=0;prime[i];i++)
if(prime[i]!='.')
printf("%c",prime[i]);
}
else if(index>=0)
{
for(int i=0;prime[i]&&i<index+2;i++)
if(prime[i]!='.')
printf("%c",prime[i]);
int judge=0;
for(int i=0;i<(int)(index-strlen(prime)+2);i++){ //cnm
judge=1;
printf("0");
}
if(judge==0&&(index-strlen(prime)+2)){
printf(".");
printf("%s",prime+index+2);
}
}
return 0;
}
1.scanf的正则化输入,