C++實(shí)現(xiàn)十六進(jìn)制字符串轉(zhuǎn)換為十進(jìn)制整數(shù)的方法
更新時(shí)間:2015年07月07日 17:02:32 作者:defias
這篇文章主要介紹了C++實(shí)現(xiàn)十六進(jìn)制字符串轉(zhuǎn)換為十進(jìn)制整數(shù)的方法,涉及C++字符串與數(shù)制轉(zhuǎn)換的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
本文實(shí)例講述了C++實(shí)現(xiàn)十六進(jìn)制字符串轉(zhuǎn)換為十進(jìn)制整數(shù)的方法。分享給大家供大家參考。具體實(shí)現(xiàn)方法如下:
/*
* 將十六進(jìn)制數(shù)字組成的字符串(包含可選的前綴0x或0X)轉(zhuǎn)換為與之等價(jià)的整型值
*/
#include <stdio.h>
#include <math.h>
/* 將十六進(jìn)制中的字符裝換為對應(yīng)的整數(shù) */
int hexchtoi(char hexch )
{
char phexch[] = "ABCDEF";
char qhexch[] = "abcdef";
int i;
for(i=0;i<6;i++){
if((hexch == phexch[i]) || (hexch == qhexch[i]))
break;
}
printf("i=%d",i);
if(i >= 6){
return 0; /* 非十六進(jìn)制字符 */
}
return 10+i;
}
int htoi(char s[])
{
int n=0; /*有n位*/
int valu=1; /*是否有效*/
int i=0,j;
int answer=0;
/* 有效性檢查 */
if((s[0] == '0') && ((s[1] == 'x') || (s[1] == 'X'))){
i += 2;
}
while((s[i] != '\n')){
if((s[i] < '0') && (s[i] > '9')){
if(hexchtoi(s[i]) == 0){
valu=0;
break;
}
}
n++;
i++;
}
if(valu != 0){
for(j=0;j<n;j++){
answer += ((int)pow(16,j) * hexchtoi(s[i-j-1]));
}
}
else
answer = -1;
return answer;
}
main()
{
char *n[] = {"0x7ff0","0x2341"};
printf("%s is %d\n",n[0],htoi(n[0]));
printf("%s is %d\n",n[0],123);
}
希望本文所述對大家的C++程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:
- C++實(shí)現(xiàn)utf8字符串和gbk字符串互轉(zhuǎn)
- C++實(shí)現(xiàn)判斷一個(gè)字符串是否為UTF8或GBK格式的方法
- C/C++實(shí)現(xiàn)數(shù)字與字符串互相轉(zhuǎn)換的多種方法
- C++中jsoncpp庫和nlohmann-json庫實(shí)現(xiàn)JSON與字符串類型轉(zhuǎn)換
- 在C++中把字符串轉(zhuǎn)換為整數(shù)的兩種簡單方法
- C++實(shí)現(xiàn)將長整型數(shù)轉(zhuǎn)換為字符串的示例代碼
- C++實(shí)現(xiàn)十六進(jìn)制字符串轉(zhuǎn)換成int整形值的示例
- c++中數(shù)字與字符串之間的轉(zhuǎn)換方法(推薦)
- C++中utf8字符串和gbk字符串的轉(zhuǎn)換方法
相關(guān)文章
Qt鍵盤事件實(shí)現(xiàn)圖片在窗口上下左右移動(dòng)
這篇文章主要為大家詳細(xì)介紹了Qt鍵盤事件實(shí)現(xiàn)圖片在窗口上下左右移動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08
C語言使用結(jié)構(gòu)體實(shí)現(xiàn)簡單通訊錄
這篇文章主要為大家詳細(xì)介紹了C語言使用結(jié)構(gòu)體實(shí)現(xiàn)簡單通訊錄,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02
如何通過C++求出鏈表中環(huán)的入口結(jié)點(diǎn)
本文主要介紹了通過C++求解鏈表中環(huán)的入口結(jié)點(diǎn),即給一個(gè)長度為n鏈表,若其中包含環(huán),請找出該鏈表的環(huán)的入口結(jié)點(diǎn),否則,返回null。需要的朋友可以參考一下2021-12-12

