1024科学记数法(C语言实现,有关测试点2,3,4)

 第一次写文章,最近在准备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);//前面输出零了后直接把后面的字符串打印出来就好。
    }
}

测试点2,3,4的情况是如果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);

就好了。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值