码迷,mamicode.com
首页 > 其他好文 > 详细

PAT_B_1024 科学计数法

时间:2019-08-04 12:00:28      阅读:86      评论:0      收藏:0      [点我收藏+]

标签:表示法   ret   define   用例   符号位   长度   div   har   表达式   

题目描述:

科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [+-][1-9].[0-9]+E[+-][0-9]+,即数字的整数部分只有 1 位,小数部分至少有 1 位,该数字及其指数部分的正负号即使对正数也必定明确给出。
现以科学计数法的格式给出实数 A,请编写程序按普通数字表示法输出 A,并保证所有有效位都被保留。
输入格式:
每个输入包含 1 个测试用例,即一个以科学计数法表示的实数 A。该数字的存储长度不超过 9999 字节,且其指数的绝对值不超过 9999。
输出格式:
对每个测试用例,在一行中按普通数字表示法输出 A,并保证所有有效位都被保留,包括末尾的 0。

输入样例 1:
+1.23400E-03
输出样例 1:
0.00123400
输入样例 2:
-1.2E+10
输出样例 2:
-12000000000

解题关键:

1. 利用字符串对数字的读入;

2. 对符号的判断,正号不必输出,负号必须输出;

3. 对指数的讨论,先把字符串转化为整数后分正负分别计算;

(1).指数为负,则在符号位后直接输出‘0.’,然后在小数点与第一位非0数之间插‘0’,不必再次输出小数点;

(2).指数为正,则判断原字符串在小数点和E之间的长度len与指数exp的大小,再判断小数点的位置。

AC代码:

// PAT_1024_科学计数法 
# include <stdio.h>
# include <string.h>
# include <stdlib.h>
# define Max 100000

int main(void)
{
	char S[Max], S_num[Max]; 
	int i=0, j=0, exp, len=0;
	gets(S);
	// puts(S);
	// 输出该数字的符号(数不必输出) 
	if (S[0] == ‘-‘)
		printf("%c",S[0]); 
	while (S[i]!=‘E‘) i++;
	// 提取E后面的数字
	strcpy(S_num, S+i+1); 
	// puts(S_num);
	// 转化为整型数字 
	exp = atoi(S_num);
	// printf("%d\n",exp);
	// 指数分正负讨论,负数时 
	if (exp<0) 
	{
		printf("0.");
		// 在小数点后面输出0
		for (j=exp; j<-1; j++) 
			printf("0"); 
		// 输出正负号到E之间的除小数点外的字符
		for (i=1; S[i]!=‘E‘; i++) 
		{
			if (S[i]!=‘.‘)
				printf("%c",S[i]);
		}
	}
	// 指数为正时 
	else
	{
		// 记录小数点到E之间的字符串长度
		for (i=2; S[i]!=‘E‘; i++)
		{
			if (S[i]!=‘.‘)
				len++;
		 } 
		 // 长度 
		 // printf("%d\n",len);
		 // 比较 指数exp 和 长度len 的大小
		 // exp>len 在最后补零,不用输出 小数点 
		 if (exp >= len) 
		 {
		 	for (i=1; S[i]!=‘E‘; i++)
		 	{
		 		if (S[i]!=‘.‘)
		 			printf("%c",S[i]);
			 }
			 for (i=0; i<exp-len; i++)
			 	printf("0");
		 }
		 // exp < len 在第exp位输出小数点 
		 else
		 {
		 	 for (i=1; S[i]!=‘E‘; i++)
			 {
			 	if (S[i] != ‘.‘)
			 		printf("%c",S[i]);
			 	if (i==exp+2)
			 		printf(".");
		     }
			  
		 } 
	}
	 
	return 0;
}

RRR

PAT_B_1024 科学计数法

标签:表示法   ret   define   用例   符号位   长度   div   har   表达式   

原文地址:https://www.cnblogs.com/Robin5/p/11297702.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!