书中AC代码

#include <cstdio>
#include <cstring>
#include <iostream>
#include <cmath>
const int max_n = 10100;
using namespace std; void Print(bool a) {
if(!a) printf("-");
}
int main() {
#ifdef ONLINE_JUDGE
#else
freopen("1.txt", "r", stdin);
#endif // ONLINE_JUDGE
// for(int j = 0; j < 10; j++) printf("%d",j);
// printf("\n");
char str[max_n];
//char index[max_n];
cin.getline(str, max_n);
bool flag1 = 0, flag2 = 0; //数字的正负, 指数的正负
int len = strlen(str);
// printf("last:%c\n", str[len - 1]);
int i = 0;
//记录数字的正负
if(str[i] == '-') {
flag1 = 0;
i++;
} else if(str[i] == '+') {
flag1 = 1;
i++;
}
int E = 0; //E的位置
for(i++; i < len; i++) {
if(str[i] == 'E') {
E = i;
break;
}
}
//记录指针的正负
if(str[i++] == '-') {
flag2 = 0;
} else if(str[i++] == '+') {
flag2 = 1;
}
//记录指针的位置
// printf("index:%c\n", str[E+1]);
//int index_set = i + 1;
int index = 0;
int t = 0;
// printf("%c %c ", str[len - 2], str[len - 1]);
// int a = pow(10, 0);
// printf(" a:%d", a);
for(int j = len - 1; j > E + 1; j--) {
index += ((str[j] - '0') * pow(10, t));
t++;
}
//printf("flag1:%d flag2:%d E:%d index:%d\n", flag1, flag2, E, index);
//打印计算结果
Print(flag1);
//指数为0
if(index == 0) {
printf("%c", str[1]); }
if(flag2 == true) { //指数为正
//E - 3 为小数位数大小
if(E - 3 == index) { //小数部分位数等于指数大小
for(int i = 1; i < E; i++) {
if(i != 2) printf("%c", str[i]);
}
}
if(E - 3 < index) {
for(int i = 1; i < E; i++) {
if(i != 2) printf("%c", str[i]);
}
for(int i = index - (E - 3); i > 0; i--) printf("0");
}
if(E - 3 > index) {
int i;
for(i = 1; i < index + 3; i++) {
if(i != 2) printf("%c", str[i]);
}
printf(".");
int a = i;
for(a; a < E; a++) {
printf("%c", str[a]);
}
}
} else if(flag2 == false) { //指数为负
printf("0.");
for(int i = 0; i < index - 1; i++) { //输出(index - 1)个0
printf("0");
}
printf("%c", str[1]); //输出整数部分的数字
for(int i = 3; i < E; i++) {
if(i != E && i != E + 1) {
printf("%c", str[i]);
}
}
}
return 0; }

PAT B1024/A1073 科学计数法的更多相关文章

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

    1024. 科学计数法 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 HOU, Qiming 科学计数法是科学家用来表示很 ...

  2. PAT乙级 1024. 科学计数法 (20)(未通过全部测试,得分18)

    1024. 科学计数法 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 HOU, Qiming 科学计数法是科学家用来表示很 ...

  3. pat 1060 比较科学计数法

    trick: 1.前导0 如:000001,000.000001 2.出现0时也要按照科学计数法输出 e.g. 4 00000.00000 0001 NO 0.0000*10^0 0.1*10^1 3 ...

  4. PAT Basic 1024 科学计数法 (20 分) Advanced 1073 Scientific Notation (20 分)

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

  5. PAT乙级 1024 科学计数法

    思路 1.尝试失败:一开始想打算把结果直接存在一个字符串中,后来发现当指数大于0的时候还需要分别考虑两种情况,工程量巨大,尝试失败,于是借鉴了其他大佬思路,写出了ac代码 2.ac思路:首先取指数的绝 ...

  6. PAT B1024科学计数法

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

  7. C#版 - PAT乙级(Basic Level)真题 之 1024.科学计数法转化为普通数字 - 题解

    版权声明: 本文为博主Bravo Yeung(知乎UserName同名)的原创文章,欲转载请先私信获博主允许,转载时请附上网址 http://blog.csdn.net/lzuacm. PAT Bas ...

  8. PAT 1024 科学计数法 (20)(精简版代码+思路+推荐测试样例)

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

  9. PAT (Basic Level) Practise (中文)- 1024. 科学计数法 (20)

    PAT (Basic Level) Practise (中文)- 1024. 科学计数法 (20) http://www.patest.cn/contests/pat-b-practise/1024 ...

随机推荐

  1. libpng warning: iCCP: known incorrect sRGB profile告警处理

    在 qt中加载某些 png图片会出现:libpng warning: iCCP: known incorrect sRGB profile   告警信息. 虽然没什么影响,但是总看到这个警告非常的不舒 ...

  2. 定义了char**p,为什么能用p[i][j]的形式?p又不是二维数组?

    char **p;p[i][j]相当于*(*(p+i)+j) https://www.zhihu.com/question/63717863

  3. HearthBuddy炉石兄弟 格雷迈恩

    getDecks(); 设置 private void getDecks() { Dictionary<string, int> tmpDeck = new Dictionary<s ...

  4. qcow2镜像制作

    windows 1.准备windows镜像.驱动镜像. 驱动下载地址: https://docs.fedoraproject.org/en-US/quick-docs/creating-windows ...

  5. mybatis之动态SQL操作之删除

    /** * 持久层 */ public class StudentDao { /** * 动态SQL--删除 */ public void dynaSQLwithDelete(int... ids) ...

  6. .SpringIOC容器

    创建对象 SpringIOC容器,是spring核心内容. 作用: 创建对象 & 处理对象的依赖关系 IOC容器创建对象: 创建对象, 有几种方式: 1) 调用无参数构造器 2) 带参数构造器 ...

  7. HTTP状态码分类及异常状态码处理

    1xx:表示临时响应100:(继续)请求者应当继续提出请求.服务器返回此代码表示已收到请求的第一部分,正在等待其余部分101:(切换协议)请求者已要求服务器切换协议,服务器已确认并准备切换 2xx:表 ...

  8. WPF学习笔记 - 如何用WPF创建单实例应用程序

    使用一个已命名的(操作系统范围的)互斥量. bool mutexIsNew; using(System.Threading.Mutex m = new System.Threading.Mulex(t ...

  9. List去重为什么要写equals(),hashCode()方法

    一,各个集合的特点: Collection(集合):容器,用于存放对象(引用类型.基本类型需要自动装箱) List(列表):元素有序,元素可以重复 (有索引). 通过元素的equals()方法判断是否 ...

  10. JAVA 自定义对象集合 List<T> 根据自定义字段去重

    1.拥有自定义对象 MyUser @Data public class MyUser { private String userName; private String passWord; } 2.编 ...