蓝桥杯基础练习超全习题题解——BASIC-10~13题(十进制转十六进制、十六进制转十进制、十六进制转八进制、数列排序)

每日刷题(三十一)

BASIC-10、十进制转十六进制

在这里插入图片描述
在这里插入图片描述
思路如下:
在这里插入图片描述
其实这根本就不算一个题,你可以直接提交一个六行代码

#include<stdio.h>

int main()
{
	int n;
	scanf("%d",&n);
	printf("%X\n", n);
	return 0;
}

正统代码如下:

#include<stdio.h>

int main()
{
	int n;
	scanf("%d", &n);
	char a[] = {48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 'A', 'B', 'C', 'D', 'E', 'F'};
	int t = n;
	int tmp = n % 16;
	char m;
	char k[100];
	int i;
	if(n / 16 == 0)
	{
		m = a[tmp];
		printf("%c", m);
		return 0;
	}
	else
	{
		i = 0;
		while(t)
		{
			k[i] = a[tmp];
			
			t = t / 16;
			tmp = t % 16;
			i++;
		}
		while(i > -1)
		{
			printf("%c", k[--i]);
		}
	}
		
	return 0;
}

部分运行结果如下:
在这里插入图片描述

BASIC-11、十六进制转十进制

在这里插入图片描述
这题也非常简单,但是要注意一点,定义数值型为long long型更保险,以免溢出

详细C代码如下:

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

int change(char a[], int i)
{
	switch(a[i])
	{
		case '0':
			return 0;
		case '1':
			return 1;
		case '2':
			return 2;
		case '3':
			return 3;
		case '4':
			return 4;
		case '5':
			return 5;
		case '6':
			return 6;
		case '7':
			return 7;
		case '8':
			return 8;
		case '9':
			return 9;
		case 'A':
			return 10;
		case 'B':
			return 11;
		case 'C':
			return 12;
		case 'D':
			return 13;
		case 'E':
			return 14;
		case 'F':
			return 15;
	}
}

int main()
{
	char a[8];
	scanf("%s", a);
	int t = strlen(a);
	long long num = 0;
	int i = 0;
	num = change(a, i);
	while(--t)
	{
		num = 16 * num + change(a, i + 1);
		i++;
	}
	printf("%lld\n", num);
	return 0;
}

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

在这里插入图片描述
特别省事的代码如下

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

int change(char a[], int i)
{
	switch(a[i])
	{
		case '0':
			return 0;
		case '1':
			return 1;
		case '2':
			return 2;
		case '3':
			return 3;
		case '4':
			return 4;
		case '5':
			return 5;
		case '6':
			return 6;
		case '7':
			return 7;
		case '8':
			return 8;
		case '9':
			return 9;
		case 'A':
			return 10;
		case 'B':
			return 11;
		case 'C':
			return 12;
		case 'D':
			return 13;
		case 'E':
			return 14;
		case 'F':
			return 15;
	}
}

int main()
{
	char a[100000];
	int n;
	scanf("%d", &n);
	int v;
	for(v = 0; v < n; v++)
	{
		scanf("%s", a);
		int t = strlen(a);
		long long num = 0;
		int i = 0;
		num = change(a, i);
		while(--t)
		{
			num = 16 * num + change(a, i + 1);
			i++;
		}
		printf("%o\n", num);
	}
		
	return 0;
}

但是因为题目要求把所有输入数据都输完后才可以输出,所以不符合要求,上面那套代码就只适合玩玩,下面才是正规解:

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

int change(char a[], int i)
{
	switch(a[i])
	{
		case '0':
			return 0;
		case '1':
			return 1;
		case '2':
			return 2;
		case '3':
			return 3;
		case '4':
			return 4;
		case '5':
			return 5;
		case '6':
			return 6;
		case '7':
			return 7;
		case '8':
			return 8;
		case '9':
			return 9;
		case 'A':
			return 10;
		case 'B':
			return 11;
		case 'C':
			return 12;
		case 'D':
			return 13;
		case 'E':
			return 14;
		case 'F':
			return 15;
	}
}

int main()
{
	char a[100000];
	int n;
	scanf("%d", &n);
	int cnt = 0;
	long long th[100000];
	int v;
	for(v = 0; v < n; v++)
	{
		scanf("%s", a);
		int t = strlen(a);
		long long num = 0;
		int i = 0;
		num = change(a, i);
		while(--t)
		{
			num = 16 * num + change(a, i + 1);
			i++;
		}
		int k[100000];
		int w = num;			 
		int u = num % 8;
		if(num / 8 == 0)
		{
			th[cnt++] = u;
			continue;
		}
		else
		{
			int z = 0;
			while(w)
			{
				k[z] = u;
				w = w / 8;
				u = w % 8;
				z++;
			}
			z--;
			long long rv = k[z];
			while(z > 0)
			{
				rv = rv * 10 + k[--z];
			}
			th[cnt++] = rv;
		}
	}
	int tc = 0;
	for(; tc < cnt; tc++)
		printf("%lld\n", th[tc]);
	return 0;
}

样例运行结果如下:
在这里插入图片描述
最后还是要吐槽一下,什么变态测试数据!
在这里插入图片描述

BASIC-13、数列排序

在这里插入图片描述
在这里插入图片描述
我这里用的是冒泡排序法,详细代码如下:

#include<stdio.h>

int main()
{
	int n;
	scanf("%d", &n);
	int a[n];
	int i;
	for(i = 0; i < n; i++)
		scanf("%d", &a[i]);
	int j;
	int tmp = 0;
	for(i = 0; i < n - 1; i++)
	{
		for(j = i + 1; j < n; j++)
		{
			if(a[i] > a[j])
			{
				tmp = a[j];
				a[j] = a[i];
				a[i] = tmp;
			}
		}
	}
	for(i = 0; i < n; i++)
		printf("%d ", a[i]);
	printf("\n");
	return 0;
}
最近我还会有更多博文更新,如果喜欢我的文章,请记得一键三连哦,点赞关注收藏,你的每一个赞每一份关注每一次收藏都将是我前进路上的无限动力 !!!↖(▔▽▔)↗ 感谢支持,下期更精彩!!!
在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 ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值