BUAA(2021春)小数形式与科学计数法转换(简)——分类讨论一定要有逻辑

48 篇文章 154 订阅

看前须知

要点介绍和简要声明.

第一次上机题汇总

扩展字符A——strchr的灵活使用.

表达式求值.

小数形式与科学计数法转换(简)——分类讨论一定要有逻辑.

超长正整数的减法(高精度减法)+其他三种高精度运算.

全排列数的生成——DFS(深度优先遍历)+回溯 秒杀本题.

题目内容

问题描述

编写一个程序,将用小数表示的浮点数,转换成科学计数法的形式输出。输入的数据没有符号,小数点前后必有数字,且全为有效数据,即小数点后的末尾数字不为0;小数点前若只有一位数字,可以为0,否则小数点前的最高位数字不为0。

提示:以字符串形式保存相关数据。

输入形式

从控制台输入一小数,最后有回车换行符,所有输入的字符数不会超过100。

输出形式

以科学计数法形式输出数据。输出的数据由以下几部分构成:
1.底数部分是一个小数或整数,若为小数,则小数点前后必有数字,而且都为有效数字。即:小数点前只有一位大于0的数字,小数点后的末尾数字不能为0。若为整数,则只有一位数字,不带小数点。
2.必有小写字母“e”。
3.指数部分是一个整数,若大于等于0,则不带正号“+”。若小于0,则需要带负号“-”,且整数的最高位数字不为0。

样例

【输入样例1】

0.000000000000002

【输出样例1】

2e-15

【输入样例2】

8.9845623489651700659

【输出样例2】

8.9845623489651700659e0

【输入样例3】

367298599999093453490394859509568659795603.4

【输出样例3】

3.672985999990934534903948595095686597956034e41

样例说明

以小数形式输入数据,然后转换成科学计数法形式输出。

题解

易错点和难点

难点就是在于怎么讨论完全所有的情况,对于这种情况比较多的题目,建议在编码操作前先在草稿纸上全部列出,同时列出的同时注意逻辑性,如果可以以较强逻辑性地形式列出所有情况,那么这题就迎刃而解了。

参考代码

#include<stdio.h>
#include<string.h>
#include<math.h>
#include<stdlib.h>
#include<ctype.h>
int main()
{	
	char s[100];
	char *p=NULL;
	int i,l;
	scanf("%s",s);
	p=strchr(s,'.');//判断小数点的位置 
	if(p==NULL)
	{
		puts(s);
	}
	else if(p-s==1)//如果是整数不大于10 
	{
		if(s[0]=='0')//判断整数部分是否为0 
		{
			for(i=2;i<strlen(s);i++)
			{
				if(s[i]!='0')//找到非0的位置 
				{
					l=i;
					break;
				}
			}
			if(l==strlen(s)-1) //如果是像0.0000000000002这样的非0数之后没有数的情况 
			{
				printf("%c",s[l]);//输出非0数 
				for(i=l+1;s[i]!='\0';i++)
				{
					printf("%c",s[i]);
				}
				printf("e-%d",l-1);
			}
			else //如果是像0.00000000000023456这样的非0数之后有数需要输出小数点的情况 
			{
				printf("%c",s[l]);
				printf(".");
				for(i=l+1;s[i]!='\0';i++)
				{
					printf("%c",s[i]);
				}
				printf("e-%d",l-1);
			}
			
		}
		else  //对于整数部分大于等于1小于10的情况,如 8.9845623489651700659 
		{
			for(i=0;i<strlen(s);i++)
			{
				printf("%c",s[i]);
			}
			printf("e0");
		} 
	}
	else //对于整数部分大于等于10 的情况,如 367298599999093453490394859509568659795603.4 
	{
		l=p-s;
		printf("%c",s[0]);
		printf(".");
		for(i=0;i<=p-s-2;i++)
		{
			printf("%c",s[i+1]);
		}
		printf("%c",s[strlen(s)-1]);
		printf("e%d",l-1);
	}
	return 0;
}

补充测试的数据

输入

0.000000000000002345667

输出

2.345667e-15

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值