輸入乙個以#結束的字串,本題要求濾去所有的非十六進製制字元(不分大小寫),組成乙個新的表示十六進製制數字的字串,然後將其轉換為十進位制數後輸出。如果在第乙個十六進製制字元之前存在字元「-」,則代表該數是負數。
輸入在一行中給出乙個以#結束的非空字串。
在一行中輸出轉換後的十進位制數。題目保證輸出在長整型範圍內。
+-p-xf4+-1!#
-3905
#include
intmain
(void);
//將得到的16進製制陣列存在numl陣列中
int index =0;
//判斷字元是否在16進製制數字前
int flag =1;
//判斷16進製制數的正負
int sum =0;
//16進製制數轉化為10進製逐位求和
int n =1;
//逐位求和位數權數
/*輸入字串,只提取保留所需的16進製制數字*/
while(1
)}/*由低位至高位逐位換算*/
for(i = len-
1; i >=
0; i--
) sum *
= flag;
//數字正負
printf
("%d"
, sum)
;}
tips:
16進製制向10進製轉化,逐位相差16倍而非10倍
字串轉換成十進位制整數
7 22 字串轉換成十進位制整數 15 分 輸入乙個以 結束的字串,本題要求濾去所有的非十六進製制字元 不分大小寫 組成乙個新的表示十六進製制數字的字串,然後將其轉換為十進位制數後輸出。如果在第乙個十六進製制字元之前存在字元 則代表該數是負數。輸入在一行中給出乙個以 結束的非空字串。在一行中輸出轉換...
字串轉換成十進位制整數
字串轉換成十進位制整數 輸入乙個以 結束的字串,本題要求濾去所有的非十六進製制字元 不分大小寫 組成乙個新的表示十六進製制數字的字串,然後將其轉換為十進位制數後輸出。如果在第乙個十六進製制字元之前存在字元 則代表該數是負數。輸入在一行中給出乙個以 結束的非空字串。在一行中輸出轉換後的十進位制數。題目...
習題7 8 字串轉換成十進位制整數
輸入乙個以 結束的字串,本題要求濾去所有的非十六進製制字元 不分大小寫 組成乙個新的表示十六進製制數字的字串,然後將其轉換為十進位制數後輸出。如果在第乙個十六進製制字元之前存在字元 則代表該數是負數。輸入在一行中給出乙個以 結束的非空字串。在一行中輸出轉換後的十進位制數。題目保證輸出在長整型範圍內。...