PAT_B_1024 科学计数法

题目描述:

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

解题关键:

1. 利用字符串对数字的读入;

2. 对符号的判断,正号不必输出,负号必须输出;

3. 对指数的讨论,先把字符串转化为整数后分正负分别计算;

(1).指数为负,则在符号位后直接输出‘0.’,然后在小数点与第一位非0数之间插‘0’,不必再次输出小数点;

(2).指数为正,则判断原字符串在小数点和E之间的长度len与指数exp的大小,再判断小数点的位置。

AC代码:

// PAT_1024_科学计数法 
# include <stdio.h>
# include <string.h>
# include <stdlib.h>
# define Max 100000

int main(void)
{
	char S[Max], S_num[Max]; 
	int i=0, j=0, exp, len=0;
	gets(S);
	// puts(S);
	// 输出该数字的符号(数不必输出) 
	if (S[0] == '-')
		printf("%c",S[0]); 
	while (S[i]!='E') i++;
	// 提取E后面的数字
	strcpy(S_num, S+i+1); 
	// puts(S_num);
	// 转化为整型数字 
	exp = atoi(S_num);
	// printf("%d\n",exp);
	// 指数分正负讨论,负数时 
	if (exp<0) 
	{
		printf("0.");
		// 在小数点后面输出0
		for (j=exp; j<-1; j++) 
			printf("0"); 
		// 输出正负号到E之间的除小数点外的字符
		for (i=1; S[i]!='E'; i++) 
		{
			if (S[i]!='.')
				printf("%c",S[i]);
		}
	}
	// 指数为正时 
	else
	{
		// 记录小数点到E之间的字符串长度
		for (i=2; S[i]!='E'; i++)
		{
			if (S[i]!='.')
				len++;
		 } 
		 // 长度 
		 // printf("%d\n",len);
		 // 比较 指数exp 和 长度len 的大小
		 // exp>len 在最后补零,不用输出 小数点 
		 if (exp >= len) 
		 {
		 	for (i=1; S[i]!='E'; i++)
		 	{
		 		if (S[i]!='.')
		 			printf("%c",S[i]);
			 }
			 for (i=0; i<exp-len; i++)
			 	printf("0");
		 }
		 // exp < len 在第exp位输出小数点 
		 else
		 {
		 	 for (i=1; S[i]!='E'; i++)
			 {
			 	if (S[i] != '.')
			 		printf("%c",S[i]);
			 	if (i==exp+2)
			 		printf(".");
		     }
			  
		 } 
	}
	 
	return 0;
}

 RRR

转载于:https://www.cnblogs.com/Robin5/p/11297702.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
REGISTER ADDRESS REGISTER DATA(1) HEX 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 1 0 LVDS_ RATE_2X 0 0 0 0 0 0 0 0 0 0 0 0 0 GLOBAL_ PDN 2 PAT_MODES_FCLK[2:0] LOW_ LATENCY_E N AVG_EN SEL_PRBS_ PAT_ FCLK PAT_MODES SEL_PRBS_ PAT_GBL OFFSET_CORR_DELAY_FROM_TX_TRIG[5:0] 3 SER_DATA_RATE DIG_GAIN_ EN 0 OFFSET_CORR_DELAY _FROM_TX_TRIG[7:6] DIG_ OFFSET_ EN 0 0 0 1 0 0 0 0 4 OFFSET_ REMOVA L_SELF OFFSET_ REMOVAL_ START_ SEL OFFEST_ REMOVAL_ START_ MANUAL AUTO_OFFSET_REMOVAL_ACC_CYCLES[3:0] PAT_ SELECT_ IND PRBS_ SYNC PRBS_ MODE PRBS_EN MSB_ FIRST DATA_ FORMAT 0 ADC_RES 5 CUSTOM_PATTERN 7 AUTO_OFFSET_REMOVAL_VAL_RD_CH_SEL 0 0 0 0 0 0 0 0 0 0 CHOPPER_EN 8 0 0 AUTO_OFFSET_REMOVAL_VAL_RD B 0 0 0 0 EN_ DITHER 0 0 0 0 0 0 0 0 0 0 0 D GAIN_ADC1o 0 OFFSET_ADC1o E GAIN_ADC1e 0 OFFSET_ADC1e F GAIN_ADC2o 0 OFFSET_ADC2o 10 GAIN_ADC2e 0 OFFSET_ADC2e 11 GAIN_ADC3o 0 OFFSET_ADC3o 12 GAIN_ADC3e 0 OFFSET_ADC3e 13 GAIN_ADC4o 0 OFFSET_ADC4o 14 GAIN_ADC4e 0 OFFSET_ADC4e 15 PAT_PRB S_LVDS1 PAT_PRBS_ LVDS2 PAT_PRBS_ LVDS3 PAT_PRBS_ LVDS4 PAT_LVDS1 PAT_LVDS2 HPF_ ROUND_ EN_ADC1-8 HPF_CORNER_ADC1-4 DIG_HPF_ EN_ADC1-4 17 0 0 0 0 0 0 0 0 PAT_LVDS3 PAT_LVDS4 0 0 18 0 0 0 0 PDN_ LVDS4 PDN_ LVDS3 PDN_ LVDS2 PDN_ LVDS1 0 0 0 0 INVERT_ LVDS4 INVERT_ LVDS3 INVERT_ LVDS2 INVERT_ LVDS1 19 GAIN_ADC5o 0 OFFSET_ADC5o 1A GAIN_ADC5e 0 OFFSET_ADC5e 1B GAIN_ADC6o 0 OFFSET_ADC6o 1C GAIN_ADC6e 0 OFFSET_ADC6e 1D GAIN_ADC7o 0 OFFSET_ADC7o 1E GAIN_ADC7e 0 OFFSET_ADC7e 1F GAIN_ADC8o 0 OFFSET_ADC8o 20 GAIN_ADC8e 0 OFFSET_ADC8e 21 PAT_PRB S_LVDS5 PAT_PRBS_ LVDS6 PAT_PRBS_ LVDS7 PAT_PRBS_ LVDS8 PAT_LVDS5 PAT_LVDS6 0 HPF_CORNER_ADC5-8 DIG_HPF_ EN_ADC5-8 23 0 0 0 0 0 0 0 0 PAT_LVDS7 PAT_LVDS8 0 0
06-09
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值