輸入乙個以#結束的字串,本題要求濾去所有的非十六進製制字元(不分大小寫),組成乙個新的表示十六進製制數字的字串,然後將其轉換為十進位制數後輸出。如果過濾後字串的首字元為「-」,代表該數是負數。
輸入格式:
輸入在一行中給出乙個以#結束的非空字串。
輸出格式:
在一行中輸出轉換後的十進位制數。題目保證輸出在長整型範圍內。
輸入樣例:
+p-xf4+-1!#輸出樣例:
-3905
主要有三個工作:
1.篩選合法字元:十六進製制的字元
2.判斷正負號
3.16->10進製
#include #include int main(int argc, const char* argv)
; int i;
int cnt = 0, first = 1, sign = 1;
/* first == 1 表示首次出現的是-
sign == 1 表示最後十進位制的數的符號
*/ while((ch = getchar()) != '#')
else if(ch>='a' && ch<='f')
else if(ch>='a' && ch<='f')
if(ch == '-' && first == 1)
sign = -1; }
int sum = 0, q = 0;
for(i = cnt-1; i >= 0; i--)
printf("%d", sign * sum);
return 0;
}
陣列 08 字串轉換成十進位制整數 15
輸入乙個以 結束的字串,本題要求濾去所有的非十六進製制字元 不分大小寫 組成乙個新的表示十六進製制數字的字串,然後將其轉換為十進位制數後輸出。如果過濾後字串的首字元為 代表該數是負數。輸入格式 輸入在一行中給出乙個以 結束的非空字串。輸出格式 在一行中輸出轉換後的十進位制數。題目保證輸出在長整型範圍...
陣列 08 字串轉換成十進位制整數 15
輸入乙個以 結束的字串,本題要求濾去所有的非十六進製制字元 不分大小寫 組成乙個新的表示十六進製制數字的字串,然後將其轉換為十進位制數後輸出。如果過濾後字串的首字元為 代表該數是負數。輸入格式 輸入在一行中給出乙個以 結束的非空字串。輸出格式 在一行中輸出轉換後的十進位制數。題目保證輸出在長整型範圍...
字串轉換成十進位制整數
7 22 字串轉換成十進位制整數 15 分 輸入乙個以 結束的字串,本題要求濾去所有的非十六進製制字元 不分大小寫 組成乙個新的表示十六進製制數字的字串,然後將其轉換為十進位制數後輸出。如果在第乙個十六進製制字元之前存在字元 則代表該數是負數。輸入在一行中給出乙個以 結束的非空字串。在一行中輸出轉換...