栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

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

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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


这个题真是学到了,先放一个自己的写法

#include
#include
#include
#include
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 

后面学习了别人的方法,发现居然可以这样输入!

#include
#include
#include
#include
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 

既然学会了这样的输入,可以更任性,转载自https://blog.csdn.net/qq_43749739/article/details/87394636?utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7EOPENSEARCH%7Edefault-1.no_search_link&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7EOPENSEARCH%7Edefault-1.no_search_link

#include 
#include 
#include 
int main()
{
    int d,e,count=0;
    char Dec[10000];
    scanf("%d.%[0-9]E%d",&d,Dec,&e);
    printf("%s",d<0 ? "-" : "");
    while( e++ < 0 )
        printf("0%s",count++==0 ? "." : "");
    e--;
    printf("%d",abs(d));
    for(int i=0 ; i 

1.scanf的正则化输入,

2.后面的处理部分好像有点复杂,先插个眼后续改进

3.“for(int i=0;i<(int)(index-strlen(prime)+2);i++)”
为什么要在这里加一个强制类型转换呢,我在测试的时候发现如果输入+1.2345E+3这里会一直循环
index是3,strlen(prime)是6,而3+2-6=-1,它应该不会进入这个循环啊,经过查询,strlen的返回值是unsigned int型,而int 和 unsigned int计算时都会被转换为unsigned int型,而结果-1它现在是一个无符号整数,我们知道int型第一位是符号位,-1第一位是1,当他被当作无符号整数,第一位就不再是符号位了,这样-1就变成了一个很大的数,所以循环会一直进行,所以用strlen和整数参与运算的时候一定要注意

一个小测试

int main()
{
	int a = -3;
	unsigned int b = 1;
	if(a+b>0)
		printf("a+b>0n");//这句话被打印
	else
		printf("a+b<0n");
	int z = a+b;
	if(z > 0)
		printf("z>0");
	else
		printf("z<0");//这句话被打印
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/303139.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号