我的PAT系列文章更新重心已移至Github,欢迎来看PAT题解的小伙伴请到Github Pages浏览最新内容。此处文章目前已更新至与Github Pages同步。欢迎star我的repo。

题目

科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式

[+-][1-9].[0-9]+E[+-][0-9]+,即数字的整数部分只有 1 位,小数部分至少有 1

位,该数字及其指数部分的正负号即使对正数也必定明确给出。

现以科学计数法的格式给出实数

,请编写程序按普通数字表示法输出

,并保证所有有效位都被保留。

输入格式:

每个输入包含 1 个测试用例,即一个以科学计数法表示的实数

。该数字的存储长度不超过 9999 字节,且其指数的绝对值不超过 9999。

输出格式:

对每个测试用例,在一行中按普通数字表示法输出

,并保证所有有效位都被保留,包括末尾的 0。

输入样例 1:

+1.23400E-03

输出样例 1:

0.00123400

输入样例 2:

-1.2E+10

输出样例 2:

-12000000000

思路

很有意思的一个题目,让我们完成一个解析科学计数法的小功能。

读取的时候用到了一种格式化字符串%[^...],这和%s类似,不过会终止于[^]里面的字符,而不是空白字符,利用这个可以简单的读取'E'前后的两个数。

解析时考虑三种情况:

指数大于(等于)0,

指数大于(等于)小数位数,末尾补0,不输出小数点,

指数小于小数位数,要在中间输出小数点,

指数小于0,在前面补0,小数点前移至第一个0后面。

代码

#include

int main()

{

int exponent; /* the exponent part */

char line[10000], *p = line;

scanf("%[^E]E%d", line, &exponent);

if(*p++ == '-') putchar('-'); /* no print if it's '+' */

if(exponent >= 0) /* print '.' later or add zeros in the end */

{

putchar(*p);

for(p += 2; exponent; exponent--) /* print the integer part */

putchar(*p ? *p++ : '0');

if(*p) /* there is still fraction part */

{

putchar('.');

while(*p) putchar(*p++);

}

}

if(exponent < 0) /* add exponent zeros in the beginning */

{

printf("0.");

for(exponent++; exponent; exponent++) /* add zeros */

putchar('0');

for(; *p; p++) if(*p != '.') putchar(*p); /* the rest */

}

return 0;

}

科学技术法c语言字符串,PAT Basic 1024. 科学计数法 (20)(C语言实现)相关推荐

  1. PAT乙级 1024. 科学计数法 (C语言)

    1024. 科学计数法 (20) 题目: 科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][1-9]"."[0-9]+E[+-][0-9]+,即 ...

  2. PAT乙级 1024 科学计数法 (20 分)

    题目内容 科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [+-][1-9].[0-9]+E[+-][0-9]+,即数字的整数部分只有 1 位,小数部分至少有 1 位,该 ...

  3. 1024 科学计数法(C语言)

    设计思路: 数字的正负号决定输出普通数字的正负 指数的正负号决定小数点的移动 编译器:C (gcc) #include <stdio.h> #include <string.h> ...

  4. 1024. 科学计数法 (20)-PAT乙级真题

    科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][1-9]"."[0-9]+E[+-][0-9]+,即数字的整数部分只有1位,小数部分至少有1位 ...

  5. (PAT乙级)1024 科学计数法(C语言实现)

    总结:(具体思路来自米狗GO的博客) 题目分析:题目规定数值最长可以是9999个字节,而指数绝对值不超过9999.而题目还要求保留所有精度,因此必须用"字符串"来处理. 思路: / ...

  6. 【PAT (Basic Level) 】1024 科学计数法 (20 分)

    科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [±][1-9].[0-9]+E[±][0-9]+,即数字的整数部分只有 1 位,小数部分至少有 1 位,该数字及其指数部 ...

  7. PAT乙级-1024 科学计数法- C语言实现(31行AC)

    考察知识点归纳: 根据题目要求输出 坑点归纳: 1.若小数部分长度等于指数值时不用在末尾加'.' 2.虽然题目说指数可能为0,实际给出指数都不为0 #include<stdio.h> in ...

  8. PAT 1024 科学计数法 (20分) C语言实现

    1024 科学计数法 (20分) 科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [±][1-9].[0-9]+E[±][0-9]+,即数字的整数部分只有 1 位,小数部 ...

  9. 【PAT乙级】1024 科学计数法 (20 分)

    题目地址 上面的精简写法: #include<cstdio> #include<iostream> #include<string> #include<alg ...

最新文章

  1. 在JavaScript中重复字符串的三种方法
  2. java 自动登录功能_jsp实现用户自动登录功能
  3. C# 利用反射调用类下的方法
  4. Centos 7 yum 安装php
  5. 零售商的“基因改造”浪潮
  6. Java后端架构开荒实战(一)——基础设施
  7. java break的用法_Java基础break、continue语句的用法
  8. linux多进程通过中断实现,Linux驱动中断上下文中会发生什么结果实验测试
  9. CoreAnimation编程指南(简介)
  10. pb调用键盘钩子的例子_搞不动Vue3.0的源码,先做个API调用师也行(新人踩坑初试)...
  11. python程序多次运行_Python内怎么使同一个.py文件多次运行?
  12. android短信模板,短信服务 · Android – Bmob后端云
  13. OrCAD(二)功能详情与实战总结
  14. java文字水印模糊_Java添加文字水印和图片水印
  15. 表情商店竞争加剧,陌陌和微信的“另一桩”生意
  16. Unity自定义Script模板
  17. 读书笔记 - 《门口的野蛮人》
  18. linux下安装以太坊(ETH/ETC)节点
  19. eclipse mysql 打包_Eclipse+Mysql+打包发布的问题......
  20. WerFault.exe 占用CPU 100%的问题处理

热门文章

  1. c语言教程变量,C语言-基础教程-C语言常量与变量
  2. C语言小游戏之扫雷完整版
  3. RK 3128 脚本生成固件
  4. C语言判断是否为素数(质数)
  5. 折戟IPO,Soul遭遇了什么?
  6. 各国语言简写代码/php 获取(判断)操作系统语言
  7. 通过NIS+NFS实现/home文件夹的共享(集群服务器共享文件节点)
  8. zip的mysql_安装zip的mysql
  9. 用Fragment来代替过期的Tabhost和ActivityGroup
  10. Origin学习分享——图形绘制