标签:表示法 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
标签:表示法 ret define 用例 符号位 长度 div har 表达式
原文地址:https://www.cnblogs.com/Robin5/p/11297702.html