1024 科学计数法 (C++)
2021/10/29 11:10:12
本文主要是介绍1024 科学计数法 (C++),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [+-][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
结尾无空行
代码:
#include <iostream> #include <math.h> #include<cstdlib> using namespace std; int main() { string str; cin>>str; if(str.at(0)=='-') cout<<'-'; str=str.substr(1); int pos=str.size()-1; while(str.at(pos)!='E'){ pos--; } int zhishu=atoi(str.substr(pos+1).c_str()); string shuzi=str.substr(0,pos); if(zhishu<0){ cout<<"0."; for(int i=1;i<zhishu*(-1);i++){ cout<<0; } cout<<shuzi.at(0); cout<<shuzi.substr(2); } else if(zhishu==0){ cout<<shuzi; } else{ int dian_pos=0; while(shuzi.at(dian_pos)!='.') dian_pos++; int shuZiWeiShu=shuzi.size()-dian_pos-1; if(zhishu>shuZiWeiShu){ cout<<shuzi.at(0); shuzi=shuzi.substr(2); cout<<shuzi; for(int i=0;i<zhishu-shuZiWeiShu;i++) cout<<0; } else if(zhishu==shuZiWeiShu){ cout<<shuzi.at(0); shuzi=shuzi.substr(2); cout<<shuzi; } else{ cout<<shuzi.at(0); shuzi=shuzi.substr(2); for(int i=0;i<zhishu;i++){ cout<<shuzi.at(i); } cout<<'.'; cout<<shuzi.substr(zhishu); } } return 0; }
这篇关于1024 科学计数法 (C++)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-27Rocket消息队列资料:新手入门指南
- 2024-11-27rocket消息队资料详解与入门指南
- 2024-11-27RocketMQ底层原理资料详解入门教程
- 2024-11-27RocketMQ项目开发资料:新手入门教程
- 2024-11-27RocketMQ项目开发资料详解
- 2024-11-27RocketMQ消息中间件资料入门教程
- 2024-11-27初学者指南:深入了解RocketMQ源码资料
- 2024-11-27Rocket消息队列学习入门指南
- 2024-11-26Rocket消息中间件教程:新手入门详解
- 2024-11-26RocketMQ项目开发教程:新手入门指南