每日一题——第一百二十四题

题目:进制转换

c 复制代码
#pragma once

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


/// <summary>
/// //将字符串表示的任意进制数转为十进制
/// </summary>
/// <param name="str">字符串</param>
/// <param name="base">当前进制数2、8、16</param>
/// <returns></returns>
long stringToDecimal(const char* str, int base)
{
	long result = 0;
	int multiplier = 1;
	int len = strlen(str);

	//从字符串末尾开始解析
	for (int i = len - 1; i >= 0; i--)
	{
		char ch = tolower(str[i]);//将字符转换为小写
		int digit = -1;

		if (ch >= '0' && ch <= '9')
		{
			digit = ch - '0';//将字符转为对应的数字
		}
		else if (base == 16 && (ch >= 'a' && ch <= 'f'))
		{
			digit = ch - 'a' + 10;
		}
		else if(ch < '0' || (ch > '9' && base != 16) || (base == 16 && ch > 'f'))//错误的情况
		{
			return 0;
		}

		//检查进制数是否在有效范围内
		if (digit >= base)
		{
			return 0;//非法字符
		}

		//累加结果
		result += digit * multiplier;
		multiplier *= base;
	}

	return result;

}


/// <summary>
/// 将十进制数转为任意的r进制数
/// </summary>
/// <param name="num"></param>
/// <param name="r"></param>
void ConvertToBaseR(int num, int r)
{
	int index = 0;
	char result[65];//假设转换后的数不超过64位

	//处理num为0的情况
	if (num == 0)
	{
		printf("0");
		return;
	}

	while (num > 0)
	{
		int remainder = num % r;//获取最后一位数字
		if (remainder < 10)
		{
			result[index++] = '0' + remainder;//余数小于10的数字, 将其转换成0~9之间的字符
		}
		else
		{
			result[index++] = 'A' + (remainder + 10);//余数大于等于10的数字, 将其转换成A ~ F之间的字符
		}

		num /= r;//更新下一次计算的数字num
	}

	result[index] = '\0';//在字符串末尾添加字符串结束符

	//由于是从低位到高位存, 所以反向打印
	for (int i = index - 1; i >= 0; i--)
	{
		printf("%c", result[i]);
	}
	printf("\n");
}
相关推荐
ShineWinsu9 小时前
对于数据结构:堆的超详细保姆级解析——下(堆排序以及TOP-K问题)
c语言·数据结构·c++·算法·面试·二叉树·
Nebula_g10 小时前
C语言应用实例:解方程(二分查找)
c语言·开发语言·学习·算法·二分查找·基础
散峰而望10 小时前
C语言刷题-编程(一)(基础)
c语言·开发语言·编辑器
异步的告白12 小时前
C语言-数据结构-1-动态数组
c语言·数据结构·c++
奔跑吧邓邓子13 小时前
【C语言实战(78)】C语言进阶:筑牢数据安全防线,密码学实战探秘
c语言·密码学·数据安全·开发实战
Herbert_hwt13 小时前
C语言循环结构完全指南:掌握for、while、do-while循环及实战应用
c语言
奔跑吧邓邓子14 小时前
【C语言实战(79)】深入C语言单元测试:基于CUnit框架的实战指南
c语言·单元测试·实战·cunit
Shylock_Mister14 小时前
弱函数:嵌入式回调的最佳实践
c语言·单片机·嵌入式硬件·物联网
攒钱植发15 小时前
嵌入式Linux——“大扳手”与“小螺丝”:为什么不该用信号量(Semaphore)去模拟“完成量”(Completion)
linux·服务器·c语言
三品吉他手会点灯16 小时前
STM32F103学习笔记-16-RCC(第3节)-使用HSE配置系统时钟并使用MCO输出监控系统时钟
c语言·笔记·stm32·单片机·嵌入式硬件·学习