C语言 - 各个进制之间的相互转换

2024-08-31 13:36

本文主要是介绍C语言 - 各个进制之间的相互转换,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一、二进制

1.二进制   >>  八进制

2.二进制   >>  十进制

3. 二进制  >>  十六进制

二、八进制

1.八进制   >>  二进制

2.八进制   >>  十进制

3.八进制   >>  十六进制

三、十进制

1.十进制   >>  二进制

2.十进制   >>  八进制

3.十进制   >>  十六进制

四、十六进制

1.十六进制   >>  二进制

2.十六进制   >>  八进制

3.十六进制   >>  十进制

一、二进制

1.二进制   >>  八进制

方法一:可以通过先将二进制转换为十进制,然后再将十进制转换为八进制的方式来间接实现
方法二:直接按每三位一组处理二进制数,并直接转换为对应的八进制数

下面为方法一的代码:

int Convert2_10(long long n)  //先将二进制数转成十进制
{int i = 0;   //用于表示第几位二进制数int n_10 = 0;  //得到的十进制数int ret = 0;  //每次取余后的数while (n != 0){ret = n % 10;n /= 10;n_10 += ret*pow(2, i);i++;}return n_10;  }int Convert2_10_8(int n) //将得到的十进制数转成八进制数
{int i = 1;int n_10 = Convert2_10(n);int n_8 = 0;while (n_10 != 0){n_8 += (n_10 % 8) * i;n_10 /= 8;i *= 10;}return n_8;
}int main()
{long long n_2 = 0;    //对于 long long,应该使用 %lld打印int n_8 = 0;printf("请输入一个二进制数:");scanf("%d", &n_2);n_8 = Convert2_10_8(n_2);printf("二进制数%lld转换为八进制数为:%d\n", n_2, n_8);return 0;
}

2.二进制   >>  十进制

int Convert2_10(const char* n)
{int sum = 0;int length = strlen(n);for (int i = 0; i < length; i++){sum += (n[i] - '0') * pow(2, length - i - 1);}return sum;
}int main()
{char n[100]; // 假设二进制数不超过99位 int ret = 0;printf("请输入一个二进制数:");scanf("%99s", &n);  // 检查输入是否有效(只包含'0'和'1')  for (int i = 0; n[i] != '\0'; i++) {if (n[i] != '0' && n[i] != '1') {printf("输入的不是有效的二进制数!!!\n");return 1;}}ret = Convert2_10(n);printf("二进制数%s转换为十进制数为:%d\n", n, ret);return 0;
}

3. 二进制  >>  十六进制

两种方法:

方法一:限制输入标准的二进制数,必须是4的倍数

char* convert2_16(const char* n)
{size_t len = strlen(n);   //计算二进制数的长度if (len == 0 || len % 4 != 0)   // 如果输入为空或长度不是4的倍数,则返回NULL{return NULL;}// 分配足够的空间来存储转换后的十六进制字符串(包括结尾的'\0')//长度为二进制长度除以4(因为4位二进制等于1位十六进制)加1(为'\0')char* hex = (char*)malloc((len / 4) + 1);if (!hex){return NULL;}// 遍历二进制字符串,每次处理4个字符size_t i, j = 0;for (i = 0, j = 0; i < len; i += 4, j++){unsigned n_16 = 0;for (size_t k = 0; k < 4; k++){n_16 = n_16 * 2 + (n[i + k] - '0');}// 将计算出的十六进制值转换为对应的字符,并存储在结果字符串中hex[j] = "0123456789ABCDEF"[(int)n_16];}hex[j] = '\0';   // 添加字符串结束符 return hex;
}
int main()
{char n_2[65];   // 假设二进制数不超过64位printf("请输入一个二进制数:");scanf("%64s", &n_2);   // 读取输入的二进制字符串(最多64位) char* hex = convert2_16(n_2);printf("二进制数%s转换成十六进制数为:0x%s\n",n_2, hex);free(hex); // 释放之前分配的内存return 0;
}

方法二:无限制输入的字符个数

int main()
{long long n_2 = 0;long int n_16 = 0;int i = 1;int remainder = 0;printf("请输入一个二进制数: ");scanf("%lld", &n_2);while (n_2 != 0){remainder = n_2 % 10;n_16 = n_16 + remainder * i;i = i * 2;n_2 = n_2 / 10;}printf("转换得到的十六进制数为: %lX\n", n_16);return 0;
}

二、八进制

1.八进制   >>  二进制

思路:先把八进制数转成十进制数,再转换成二进制数

int convert8_10(int n)   //8 >> 10
{int n_10 = 0;int i = 0;while (n != 0){n_10 += (n % 10) * pow(8, i);i++;n /= 10;}return n_10;}long long convert8_10_2(int n)  //10 >> 2
{long long n_2 = 0;int n_10 = convert8_10(n);   //得到十进制数int i = 1;while (n_10 != 0){n_2 += (n_10 % 2) *i;n_10 /= 2;i *= 10;}return n_2;
}int main()
{int n_8 = 0;long long n_2 = 0;printf("请输入一个八进制数:");scanf("%d", &n_8);n_2 = convert8_10_2(n_8);printf("八进制数%d转换为二进制数为:%lld\n", n_8, n_2);return 0;
}

2.八进制   >>  十进制

例子:1234(8进制)= 1*8^3+2*8^2+3*8^1+4*8^0=668(10进制)。

int Convert8_10(long long n)
{int num = 0; int i = 0;while (n != 0){num += (n % 10) * pow(8, i);i++;n /= 10;}return num;
}int main()
{int n_8 = 0;int n_10 = 0;printf("请输入一个八进制数:");scanf("%d", &n_8);n_10 = Convert8_10(n_8);printf("八进制数%d转换为十进制数为:%d\n", n_8, n_10);return 0;
}

3.八进制   >>  十六进制

C语言中转换八进制到十六进制可以使用sprintf()函数。

int main()
{long n_8 = 0;char n_16[10];printf("请输入一个八进制数:");scanf("%o", &n_8);sprintf(n_16, "%X", n_8);printf("八进制数%o转换成十六进制数为:%s\n", n_8, n_16);return 0;
}

三、十进制

1.十进制   >>  二进制

/两个参数:一个十进制数n;一个指向字符数组(字符串)的指针binary,这个字符数组将用于存储转换后的二进制数。
void Convert10_2(int n, char *binary)   
{int i = 0;    // 用于跟踪在binary数组中当前的位置while (n > 0) {binary[i++] = (n % 2) + '0'; //计算n除以2的余数,这个余数就是n的二进制表示中的最低位//然后将这个余数加上字符'0'的ASCII码值,将其转换为对应的字符'0'或'1'// 并将这个字符存储在binary数组的当前位置n /= 2;// 更新n为n除以2的商,为下一次迭代准备 }// 添加字符串结束符  binary[i] = '\0';// 因为我们是从最低位开始存储的,所以需要反转字符串  int start = 0;int end = i - 1;while (start < end){char temp = binary[start];binary[start] = binary[end];binary[end] = temp;start++;end--;}
}int main()
{int n_10 = 0;char n_2[33]; // 假设整数不超过32位  printf("请输入一个十进制数:");scanf("%d", &n_10);Convert10_2(n_10, n_2);printf("十进制数%d转换为二进制数为:%s\n", n_10, n_2);return 0;
}

2.十进制   >>  八进制

long convert10_8(int n)
{int n_8 = 0, i = 1;// 从十进制数开始迭代while (n != 0){n_8 += (n % 8) * i;n /= 8;i *= 10;}return n_8;
}int main()
{int n_10;printf("请输入一个十进制数: ");scanf("%d", &n_10);long n_8 = convert10_8(n_10);printf("十进制数%d转换成八进制数为:%ld\n", n_10, n_8);return 0;
}

3.十进制   >>  十六进制

int main()
{int n_10 = 0;char n_16[10];printf("请输入一个十进制数:");scanf("%d", &n_10);sprintf(n_16, "%X", n_10); // 将十进制数转成十六进制字符串printf("十进制数%d转换成十六进制数为:%s\n", n_10, n_16); // 输出十六进制数return 0;
}

四、十六进制

1.十六进制   >>  二进制

int main()
{char hex[17];  //定义一个数组int i = 0;// 读入16进制数printf("请输入16进制数:");scanf("%s", &hex);printf("对应的2进制数为:");while (hex[i]) {switch (hex[i]) {case '0':printf("0000");break;case '1':printf("0001");break;case '2':printf("0010");break;case '3':printf("0011");break;case '4':printf("0100");break;case '5':printf("0101");break;case '6':printf("0110");break;case '7':printf("0111");break;case '8':printf("1000");break;case '9':printf("1001");break;case 'A':case 'a':printf("1010");break;case 'B':case 'b':printf("1011");break;case 'C':case 'c':printf("1100");break;case 'D':case 'd':printf("1101");break;case 'E':case 'e':printf("1110");break;case 'F':case 'f':printf("1111");break;default:printf("\n错误:无效的16进制数!\n");return 0;}i++;}return 0;
}

2.十六进制   >>  八进制

基本思路:可以通过:16 >> 10 >> 8

int main()
{char n_16[10];int n_8 = 0;printf("请输入一个十六进制数:");scanf("%s", &n_16);long int n_10 = strtol(n_16, NULL, 16);   //16 >> 10int i = 1;while (n_10 != 0)  //10 >> 8{n_8 += (n_10 % 8) * i;n_10 /= 8;i *= 10;}printf("十六进制数%s转换成八进制数为:%d\n", n_16, n_8);return 0;
}

3.十六进制   >>  十进制

可以使用C语言中的strtol函数来将十六进制字符串转换为十进制数
基本结构:long int strtol(const char *str, char **endptr, int base);
其中,第一个参数str是需要转换的字符串;
            第二个参数endptr是一个指向字符指针的指针,用于存储转换后未处理的部分;
            第三个参数base是转换后的数值进制,一般使用16表示十六进制。

int main()
{char n_16[10];printf("请输入一个十六进制数:");scanf("%s", &n_16);long int n_10 = strtol(n_16, NULL, 16);printf("十六进制数%s转换成十进制数为:%d\n", n_16, n_10);return 0;
}

这篇关于C语言 - 各个进制之间的相互转换的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1124047

相关文章

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

Go语言中json操作的实现

《Go语言中json操作的实现》本文主要介绍了Go语言中的json操作的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 一、jsOChina编程N 与 Go 类型对应关系️ 二、基本操作:编码与解码 三、结构体标签(Struc

Java轻松实现PDF转换为PDF/A的示例代码

《Java轻松实现PDF转换为PDF/A的示例代码》本文将深入探讨Java环境下,如何利用专业工具将PDF转换为PDF/A格式,为数字文档的永续保存提供可靠方案,文中的示例代码讲解详细,感兴趣的小伙伴... 目录为什么需要将PDF转换为PDF/A使用Spire.PDF for Java进行转换前的准备通过

python语言中的常用容器(集合)示例详解

《python语言中的常用容器(集合)示例详解》Python集合是一种无序且不重复的数据容器,它可以存储任意类型的对象,包括数字、字符串、元组等,下面:本文主要介绍python语言中常用容器(集合... 目录1.核心内置容器1. 列表2. 元组3. 集合4. 冻结集合5. 字典2.collections模块

基于Go语言开发一个 IP 归属地查询接口工具

《基于Go语言开发一个IP归属地查询接口工具》在日常开发中,IP地址归属地查询是一个常见需求,本文将带大家使用Go语言快速开发一个IP归属地查询接口服务,有需要的小伙伴可以了解下... 目录功能目标技术栈项目结构核心代码(main.go)使用方法扩展功能总结在日常开发中,IP 地址归属地查询是一个常见需求:

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam