BUAA数据结构第一次作业题解——小数形式与科学计数法转换

【问题描述】

编写一个程序,将用小数表示的浮点数,转换成科学计数法的形式输出。输入的数据没有符号,小数点前后必有数字,且全为有效数据,即小数点后的末尾数字不为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

【样例说明】

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

【评分标准】

该题要求以科学计数法形式输出数据,提交程序文件名为notation.c。

【思路】
1.分情况讨论,从简单的往后写
2.注意如何将数字部分提取出来

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define MAX 128

int main()
{
	char str[MAX];
	gets(str);
	int len=strlen(str);
    /*可分为以下情况
    1.整数部分大于1小于10
	2.整数部分大于等于10
	3.整数部分小于1*/
	
	/*情况一*/
	if(str[0]>'0'&&str[1]=='.')
	{
		for(int i=0;i<len;i++)
		{
			printf("%c",str[i]);
		}		
		printf("e0");
		
	} 
	/*情况二*/
	else if(str[0]>'0'&&str[1]!='.')
	{
		char ans[MAX];//存储数字
		int cnt=0;
		int sig;//标记'.'在哪一位 
		for(int i=0;i<len;i++)
		{
			if(str[i]!='.')
			{
				ans[cnt++]=str[i];
			}
			else{
				sig=i;
			} 
		} 
		printf("%c.",ans[0]);
		for(int i=1;i<len-1;i++)
		{
			printf("%c",ans[i]);
		}
		printf("e%d",sig-1);
	}
	/*情况三*/
	else if(str[0]=='0')
	{
		char ans[MAX];//存储数字
		int cnt=0;		
		int i=2;
		while(str[i]=='0')
		{
			i++;
		}//找到小数部分不为0的开头 
		for(int z=i;z<len;z++)
		{
			ans[cnt++]=str[z];//存数字 
		}
		if(cnt==1)//小数部分只有1位有效数字时 
		{
			printf("%ce-%d",ans[0],i-1);
		}
		else{
			printf("%c.",ans[0]);
			for(int i=1;i<cnt;i++)
			{
				printf("%c",ans[i]);
			}
			printf("-e%d",i-1);
		} 
	}
	return 0;
}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值