陣列 08 字串轉換成十進位制整數 15

2021-07-03 13:24:21 字數 903 閱讀 1629

輸入乙個以#結束的字串,本題要求濾去所有的非十六進製制字元(不分大小寫),組成乙個新的表示十六進製制數字的字串,然後將其轉換為十進位制數後輸出。如果過濾後字串的首字元為「-」,代表該數是負數。

輸入格式:

輸入在一行中給出乙個以#結束的非空字串。

輸出格式:

在一行中輸出轉換後的十進位制數。題目保證輸出在長整型範圍內。

輸入樣例:

+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 分 輸入乙個以 結束的字串,本題要求濾去所有的非十六進製制字元 不分大小寫 組成乙個新的表示十六進製制數字的字串,然後將其轉換為十進位制數後輸出。如果在第乙個十六進製制字元之前存在字元 則代表該數是負數。輸入在一行中給出乙個以 結束的非空字串。在一行中輸出轉換...