ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

1024 科学计数法(用C语言精简的解决每日两题)

2021-10-09 17:03:34  阅读:200  来源: 互联网

标签:prime 1024 include index int C语言 printf 计数法 strlen


在这里插入图片描述
这个题真是学到了,先放一个自己的写法

#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的正则化输入,

标签:prime,1024,include,index,int,C语言,printf,计数法,strlen
来源: https://blog.csdn.net/weixin_45828712/article/details/120674097

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有