日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁(yè) 編程語言 正文

C語言實(shí)現(xiàn)十六進(jìn)制轉(zhuǎn)換為十進(jìn)制的方法詳解_C 語言

作者:暢游星辰大海 ? 更新時(shí)間: 2022-12-26 編程語言

題目描述

輸入一個(gè)十六進(jìn)制數(shù)字串,將其轉(zhuǎn)換成為對(duì)應(yīng)的整數(shù)并輸出轉(zhuǎn)換結(jié)果,遇到非十六進(jìn)制數(shù)字或字符串結(jié)束符('\0')結(jié)束轉(zhuǎn)換。

注意: 輸入的字符串的長(zhǎng)度不會(huì)超過100;轉(zhuǎn)換后的值不會(huì)超出int類型的范圍。

1.測(cè)試輸入:55 //程序的輸入不會(huì)有十六進(jìn)制的前綴

預(yù)期輸出:85

2.測(cè)試輸入:f1r2 //程序的輸入不會(huì)有十六進(jìn)制的前綴

預(yù)期輸出:241

補(bǔ)充知識(shí)

十六進(jìn)制轉(zhuǎn)換為十進(jìn)制的做法:

算法分析

#include<stdio.h>
#include<string.h>
void conversion(char str[]){
    /**********  Begin  **********/
    int i=0,j=0,num=0,sum=0;
    int len=strlen(str);
 
    while(str[i]!='\0')
    {
        if(str[i]>='0'&&str[i]<='9')
           num=str[i]-'0';
        else if(str[i]>='a'&&str[i]<='f')
           num=str[i]-'a'+10;
        else if(str[i]>='A'&&str[i]<='F')
           num=str[i]-'A'+10; 
        else
           break;
        for(j=0;j<len-1;j++)
        {
            num=num*16;
        }
        sum+=num;   
        i++;
        len--;
    }
    printf("%d",sum);
    /**********  End  **********/
}

上面代碼不夠完善,當(dāng)遇到一些特殊情況(當(dāng)出現(xiàn)非16進(jìn)制的字符的時(shí)候)就會(huì)出錯(cuò),例如:

測(cè)試輸入:5r //程序的輸入不會(huì)有十六進(jìn)制的前綴

預(yù)期輸出:5

實(shí)際輸出:80

問題在于:

我們使用字符的長(zhǎng)度n(程序中以len代替)來決定 5*,r也被記錄在內(nèi),導(dǎo)致多乘了一個(gè)16。

而且對(duì)循環(huán)的結(jié)束條件設(shè)置的不合理,如果輸入的例子為5r123,那么就會(huì)被計(jì)算為

優(yōu)化算法

#include<stdio.h>
#include<string.h>
void conversion(char str[]) 
{
    /**********  Begin  **********/
    int i = 0, j=0,num = 0, sum = 0,len=0;
    //int len = strlen(str);//這種方法會(huì)將非16進(jìn)制數(shù)記錄在內(nèi)
    while ((str[i] >= 'a' && str[i] <= 'f') || (str[i] >= 'A' && str[i] <= 'F') || (str[i] >= '0' && str[i] <= '9'))
    {
        len++;
        i++;
    } //遍歷數(shù)組記錄16進(jìn)制數(shù)的個(gè)數(shù),非16進(jìn)制數(shù)不計(jì)在內(nèi) 
    i = 0;
    while (str[i] != '\0')
    {
        //字符轉(zhuǎn)數(shù)字
        if (str[i] >= '0' && str[i] <= '9')
            num = str[i] - '0';
        else if (str[i] >= 'a' && str[i] <= 'f')
            num = str[i] - 'a' + 10;
        else if (str[i] >= 'A' && str[i] <= 'F')
            num = str[i] - 'A' + 10;
        else
            break;//遇到'\0'之前的第一個(gè)非十六進(jìn)制數(shù)就停止循環(huán)
        for (j = 0; j < len - 1; j++)
        {
            num = num * 16;
        }
        sum += num;
        i++;
        len--;//每讀取一位就使長(zhǎng)度-1
    }
    printf("%d\n", sum);
    /**********  End  **********/
}

補(bǔ)充辦法

除了以上方法,小編為為大家整理了一些其他方法實(shí)現(xiàn)十六進(jìn)制轉(zhuǎn)十進(jìn)制,需要的可以參考一下

#include<stdio.h>
#include<ctype.h>
int Get_0x(const char *str)
{
	int sum = 0;
	while(isspace(*str))
	{
		str++;
	}
	//此時(shí) 空格處理結(jié)束
	int index = 1;
	if(*str=='-' || *str=='+')
	{
		if(*str=='-')
		{
			index *= -1;
		}
		else
		{
			index = 1;
		}
		str++;
	}
	
	if((*str=='0') && (*(str+1)=='x'|| *(str+1)=='X'))
	{
		str+=2;
	}
	else
	{
		return INT_MAX;
	}
 
	while(isxdigit(*str))
	{
		if(isdigit(*str))
		{
			sum = sum*16 + (*str-'0'); 
		}
		else if(islower(*str))
		{
			sum = sum*16 + (*str-'a'+10);
		}
		else
		{
			sum = sum*16 + (*str-'A'+10);
		}
		str++;
	}
	if(*str == '\0')
		return sum * index;
	return INT_MAX;
}
int main()
{
	printf("%d\n", Get_0x("0x123ABcW"));
	printf("%d\n", Get_0x("0X123ABc"));
	printf("%d\n", Get_0x("      0x123ABc"));
	printf("%d\n", Get_0x("+0x123ABc"));
	printf("%d\n", Get_0x("-0x123ABc"));
	printf("%d\n", Get_0x("  +0x123ABc"));
	printf("%d\n", Get_0x("   -0x123ABc"));
    return 0;
}

調(diào)試結(jié)果

原文鏈接:https://blog.csdn.net/m0_73222051/article/details/128065456

欄目分類
最近更新