習題7-8 字串轉換成十進位制整數 (15 point(s))
阿新 • • 發佈:2018-11-25
習題7-8 字串轉換成十進位制整數 (15 point(s))
輸入一個以#結束的字串,本題要求濾去所有的非十六進位制字元(不分大小寫),組成一個新的表示十六進位制數字的字串,然後將其轉換為十進位制數後輸出。如果在第一個十六進位制字元之前存在字元“-”,則代表該數是負數。
輸入格式:
輸入在一行中給出一個以#結束的非空字串。
輸出格式:
在一行中輸出轉換後的十進位制數。題目保證輸出在長整型範圍內。
輸入樣例:
+-P-xf4+-1!#
輸出樣例:
-3905
#include<stdio.h> int main(){ char a[100]; gets(a); int i,flag=0,f=0,sum=0; for(i=0;a[i]!='#';i++){ if(a[i]=='-'&&flag==0) f=1; else if(a[i]>='a'&&a[i]<='f'){ sum=sum*16+a[i]-'a'+10; flag=1; } else if(a[i]>='A'&&a[i]<='F'){ sum=sum*16+a[i]-'A'+10; flag=1; } else if(a[i]>='0'&&a[i]<='9'){ sum=sum*16+a[i]-'0'; flag=1; } } if(f==1) sum=-sum; printf("%d",sum); return 0; }