PAT B1024. 科学计数法 (20)

1024 科学计数法 (20 分)
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [±][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

思路:

string型变量str存放输入字符串,int型变量len存放str的长度,pos存放该字符串E的位置,exp存放指数。
while循环判断E的位置,for循环计算指数(不考虑正负,需特别判断exp等于0的情况即直接输出)。若指数为负,则输出0.,再输出exp-1个零,之后输出除小数点以外的数;若指数为正,输出除小数点之外的数,在exp+2位置输出小数点,其中小数点和E之间的数字个数pos-3不能等于小数点右移位数exp即小数点不能在结尾;假若exp较大,则要输出多余的0。

参考代码:

#include <cstdio>
#include <iostream> 
#include <cstring>
using namespace std;
int main(){
	char str[10010];
	cin>>str;
	int len =strlen(str);
	if(str[0]=='-') printf("-");//若是负数则输出负号;
	int pos=0;//pos 存放字符串中E的位置; 
	while(str[pos]!='E'){
		pos++;
	} 
	int exp=0;//exp存放指数,先不考虑正负;
	for (int i=pos+2;i<len;i++){//从正负号开始 
		exp=exp*10+(str[i]-'0');
	} 
	if(exp==0){//特判指数为0的情况; 
		for (int i=0;i<pos;i++){
			printf("%c",str[i]);
		}
	}
	if(str[pos+1]=='-'){
		printf("0.");
		for (int i=0;i<exp-1;i++){//输出(exp-1)个零; 
			printf("0");
		}
		printf("%c",str[1]);//输出出小数点以外的数;
		for(int i=3;i<pos;i++){
			printf("%c",str[i]);
		} 
	} 
	else{
		for(int i=1;i<pos;i++){
			if(str[i]=='.') continue;//遇到小数点不输出 
			printf("%c",str[i]);
			if(i==exp+2&&pos-3!=exp){//小数点加在(exp+2)上,
			//原小数点和E之间的数字个数(pos-3)不能等于小数点右移位数exp(小数点不能放在数字末尾) 
				printf("."); 
			}
		}
		//如果指数exp较大,输出多余的0;
		for(int i=0;i<exp-(pos-3);i++){
			printf("0");
		} 
	}
	return 0;
} 

点评:

①此题属于字符串处理型,题意较繁琐,需要考虑的情况比较多,耐下心不难。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值