标签:表示法 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