蓝桥杯基础练习超全习题题解VIP版——BASIC-12.十六进制转八进制***(方法二)

每日刷题(五十三)

BASIC-12、十六进制转八进制

在这里插入图片描述
之前我也出过关于这个题的题解博客,这次我换一种方法,就是把十六进制每个位转化为十进制数,然后再将十进制数转化为二进制数,再由二进制数转化为八进制数。

我们知道八进制数是3个2为一个组合,十六进制数是4个2为一个组合。

由于内存不能开太大了,要不然会溢出,所以我设了两个数组,一个字符数组用来记录输入的字符串,另一个int型数组的长度需要大一些,因为我需要存放二进制数。当存好二进制数后我们需要每三个转换为八进制数,需要用到sum来记录八进制数,再把其他数字标记为-1,目的是为了之后输出方便。

详细代码如下:

#include<stdio.h>
#include<string.h>
#include<math.h>

int main()
{
	int n;
	scanf("%d", &n);
		
	int v = 0;
	while(n)
	{
		char a[100000];			//用来存放十六进制数 
		int b[400000];			//用来存放二进制数
		scanf("%s", a);
		memset(b, 0, sizeof(b));
		int l = 0; 				//二进制总长度 
		int i = strlen(a);
		int cnt = 0;
		for(i -= 1; i >= 0; i--)
		{
			if(a[i] >= 'A' && a[i] <= 'F')
				cnt = a[i] - 'A' + 10;		//先转化为十进制 
			else if(a[i] >= '0' && a[i] <= '9')
				cnt = a[i] - 48;
			int j;
			int t = 0;
			for(j = 0; j < 4; j++)		//再转化为二进制 
			{
				t = cnt % 2;
				cnt /= 2;
				b[l++] = t;
			} 
		}
		v = l - 1;
		int flag = 0;
		int sum = 0;
		for(l = 0; l <= v; l++)		//再由二进制转化为八进制 
		{
			if(flag < 3)
			{
				sum += pow(2, flag) * b[l];
				b[l] = -1;
				flag++; 
			}
			else if(flag == 3)
			{
				l -= 1;
				b[l] = sum;
				sum = 0;
				flag = 0;
			}
			if(l == v)
			{
				b[l] = sum;
			}
		}
		
		int cv = v;
		for(; cv >= 0; cv--)
		{
			if(b[cv] == -1)
				continue;
			else
				printf("%d", b[cv]);
		}
		printf("\n");
		n--;
	}
	
	return 0;
}

部分运行代码如下:
在这里插入图片描述
在这里插入图片描述
我真的要吐槽一下蓝桥杯这题的测试数据,从第八个开始往后走,部分数据根本输不进去了,我怀疑gets()函数有局限性

如果喜欢我的文章,请记得三连哦,点赞关注收藏,你的每一个赞每一份关注每一次收藏都将是我前进路上的无限动力 !!!↖(▔▽▔)↗感谢支持,下期更精彩!!!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在Python中,可以使用int()函数将十六进制换为十。int()函数的第一个参数是要换的十六进制数,第二个参数是基数,表示当前的,默认为十。所以,如果要将十六进制换为十,只需要将十六进制数作为int()函数的第一个参数即可。以下是一个示例代码: hex_num = "1A" # 十六进制数 dec_num = int(hex_num, 16) # 将十六进制换为十 print(dec_num) # 输出结果为26 在上面的示例中,hex_num是要换的十六进制数,int(hex_num, 16)将hex_num换为十,结果存储在dec_num中。最后,通过print()函数将结果打印出来,结果为26。请注意,int()函数的第二个参数base需要指定为16,以表示当前要换的是十六进制数。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* [基于Python实现,可实现十换二、十换八、十十六进制十六进制换](https://download.csdn.net/download/sallyyellow/87378653)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [蓝桥杯 基础练习 十六进制 python题解 (一行代码)](https://blog.csdn.net/qq_36895331/article/details/112442715)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值