PAT 乙级练习题1024. 科学计数法 (20)
来源:互联网 发布:win10系统自带优化 编辑:程序博客网 时间:2024/06/05 03:06
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][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
用C写程序需要了解非常多的库函数。
在这里利用了strchr函数。(查找字符串s中首次出现字符c的位置,返回首次出现c的位置的指针,如果s中不存在c则返回NULL。)
atoi()函数(将字符串转化为整型数字)
再者就是要区分小数部分的正负号和指数部分的正负号。以及小数点移动的位数。
代码很长,边写边调试出来的,以后有时间可以修改一下。
#include<stdio.h>#include<string.h>#include <stdlib.h>int main(){ char s[20000],rnt[20000] ;char *f;int w,i,j;gets(s);f=strchr(s,'E');f[0]='\0';f++;w=atoi(f);if(w<0){w=-w;if(s[0]=='+'){rnt[0]='0';rnt[1]='.';for(i=2;i<=w;i++){rnt[i]='0';}for(j=0;s[j]!='\0';j++){if(s[j]>='0'&&s[j]<='9'){rnt[i]=s[j];i++;}}}if(s[0]=='-'){rnt[0]='-';rnt[1]='0';rnt[2]='.';for(i=3;i<=w+1;i++){rnt[i]='0';}for(j=0;s[j]!='\0';j++){if(s[j]>='0'&&s[j]<='9'){rnt[i]=s[j];i++;}}}}else{if(s[0]=='+'){rnt[0]=s[1];for(i=1,j=3;s[j]!='\0'&&i<=w;j++){if(s[j]>='0'&&s[j]<='9'){rnt[i]=s[j];i++;}}if(i>w){if(s[j]!='\0'){rnt[i++]='.';}for(;s[j]!='\0';j++){if(s[j]>='0'&&s[j]<='9'){rnt[i]=s[j];i++;}}}if(s[j]=='\0'){for(;i<=w;i++){rnt[i]='0';}}}if(s[0]=='-'){rnt[0]='-';rnt[1]=s[1];for(i=2,j=3,w++;s[j]!='\0'&&i<=w;j++){if(s[j]>='0'&&s[j]<='9'){rnt[i]=s[j];i++;}}if(i>w){if(s[j]!='\0'){rnt[i++]='.';}for(;s[j]!='\0';j++){if(s[j]>='0'&&s[j]<='9'){rnt[i]=s[j];i++;}}}if(s[j]=='\0'){for(;i<=w;i++){rnt[i]='0';}}}}rnt[i]='\0';printf("%s",rnt);return 0; }
阅读全文
0 0
- PAT 乙级练习题1024. 科学计数法 (20)
- PAT乙级练习题B1024.科学计数法
- PAT-乙级-1024. 科学计数法 (20)
- PAT乙级.1024. 科学计数法 (20)
- PAT乙级 1024. 科学计数法 (20)
- PAT 乙级 1024. 科学计数法 (20)
- PAT 乙级 1024. 科学计数法 (20)
- PAT乙级 1024. 科学计数法 (20)
- PAT乙级1024. 科学计数法 (20)
- [PAT乙级]1024. 科学计数法 (20)
- PAT乙级1024. 科学计数法 (20)
- pat 乙级 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)--PAT乙级
- PAT 乙级 1024. 科学计数法
- [PAT-乙级]1024.科学计数法
- PAT乙级题1024.科学计数法
- PAT乙级 科学计数法 (20)
- PAT乙级—1024. 科学计数法 (20)-native
- JZOJ5401. 【NOIP2017提高A组模拟10.8】Star Way To Heaven
- 两个数比较
- Codeforces Round #401 (Div. 2) D. Cloud of Hashtags
- ffmpeg下载安装的步骤
- Android——线程中的通信(一)
- PAT 乙级练习题1024. 科学计数法 (20)
- 从零开始学SpringBoot笔记002(热部署)
- HTTP Live Streaming(HLS)详解
- springmvc 异常001---在SpringMVC中使用@RequestBody注解处理json时,报出HTTP Status 415的解决方案
- MFC中使用任务栏显示图标表示程序最小化
- 简单的前端渲染模板实现
- 如何看懂照片的直方图
- ios下button input checkbox radio 默认样式去除
- 274. H-Index