1. 程式人生 > >1024. 科學計數法 (20) (scanf 按正則表示式進行拆分)

1024. 科學計數法 (20) (scanf 按正則表示式進行拆分)

科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正則表示式[+-][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

核心:利用scanf的正則對數進行拆分,scanf使用可見:點選開啟連結

#include<stdio.h>
#include<algorithm>
#include<math.h>
using namespace std;
//大數,採用字元陣列儲存,把大數處理當做字元處理
//利用scanf正則分解得到各位,根據要求移位輸出
int main(){
	char flag;//正符號
	char a[10000]={0};//把整數部分放在a[0]
	int ex;
	scanf("%c%c.%[0-9]E%d",&flag,&a[0],a+1,&ex);
	if(flag=='-')	printf("-");

	if(ex<0){
		printf("0.");
		for(int i=0;i<abs(ex);i++){
			printf("0");
		}
		printf("%s",a);
	}
	else{
		//沒到原數結尾時:移動小數點,到達後,不輸出小數點,開始輸出0;
		for(int i=0;i<=ex || a[i]!=0;i++){
			if(i==ex+1){//小數點移動完畢,數字還未完全輸出
				printf(".");
			}
			if(a[i]==0){//移動到末尾,但未完全結束
				printf("0");
			}
			else printf("%c",a[i]);
		}
		
	}
	return 0;
}