1024. 科学计数法 (20)
2016-06-01 14:14
274 查看
1024. 科学计数法 (20)
时间限制 100 ms内存限制 65536 kB
代码长度限制 8000 B
判题程序 Standard
作者 HOU, Qiming
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][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
原题地址: https://www.patest.cn/contests/pat-b-practise/1024
这道题刚开始没有看清楚,因为整数部分可以是0,,自己弄麻烦了,导致最后两个test没有过,今天看了别人的代码才明白,但也是测试了好久才过。
计算出小数部分的位数分清楚情况可以了
#include <iostream> #include <algorithm> #include <cmath> #include <cstdio> #include <cstring> #include <cctype> using namespace std; char str[10000]; void solve() { char num[10000] = {0}; //去掉小数点后的数字串 int len = strchr(str, 'E') - str - 3; //小数部分长度 num[0] = str[1]; strncpy(num + 1, str + 3, len); int ex = atoi(str + len + 4); //获取指数 int pos = 1; //小数点位置 if(str[0] == '-') cout << '-'; if(ex > 0){ pos += ex; if(len < ex){ cout << num; for(int i = len; i < ex; i ++) cout << '0'; } else if(len > ex){ for(int i = 0; i < pos; i ++) cout << num[i]; cout << '.'; for(int i = pos; i < len + 1; i ++) cout << num[i]; } else{ cout << num; } } else if(ex < 0) { cout << "0."; for(int i = ex + 1; i < 0; i ++){ cout << '0'; } for(int i = 0; i < len + 1; i ++) cout << num[i]; } else{ for(int i = 0; i < pos; i ++) cout << num[i]; cout << '.'; for(int i = pos; i < len + 1; i ++) cout << num[i]; } cout << endl; } int main() { cin >> str; solve(); return 0; }
相关文章推荐
- 如何组织构建多文件 C 语言程序(二)
- 如何写好 C main 函数
- Lua和C语言的交互详解
- 关于C语言中参数的传值问题
- 简要对比C语言中三个用于退出进程的函数
- 深入C++中API的问题详解
- 基于C语言string函数的详解
- C语言中fchdir()函数和rewinddir()函数的使用详解
- C语言内存对齐实例详解
- C语言编程中统计输入的行数以及单词个数的方法
- C语言自动生成enum值和名字映射代码
- C语言练习题:自由落体的小球简单实例
- 使用C语言判断英文字符大小写的方法
- c语言实现的带通配符匹配算法
- C语言实现顺序表基本操作汇总
- C语言中进制知识汇总
- C语言中计算正弦的相关函数总结
- 使用C语言详解霍夫曼树数据结构
- C语言实现选择排序、冒泡排序和快速排序的代码示例
- 探讨C语言的那些小秘密之断言