1161转进制(C语言)

一:题目

二:思路分析

1.首先该题目让我们使用递归求十进制转其他进制

2.其次,我们要知道十进制转换为其他进制怎么转换,以例题所给的数据为例

由此图可以看出,十进制转换为其他进制,是辗转相除法,即这个数一直除以要转换的进制数,一直到商为零,然后逆序输出所有余数

3.用递归图表示为

4.分析到这里大致的代码已经有雏形了,还有一个问题是,在余数在1~9时,直接输出就可以,但是余数是10~15时,不可以直接输出,要转换为A~F,怎么转换呢?

三:代码

复制代码
#include <stdio.h>
//1161转进制
void  Func(int x, int m)
{
	if (x == 0)
		return;
	else
	{
		Func(x / m,m);
		if (x % m < 10)
			printf("%d", x % m);
		else
			printf("%c", (char)(x % m + 55));
	}

}
int main()
{
	int x = 0, m = 0;
	scanf("%d %d", &x, &m);
	Func(x, m);
}
相关推荐
xlq2232211 小时前
22.多态(上)
开发语言·c++·算法
666HZ66611 小时前
C语言——高精度加法
c语言·开发语言·算法
sweet丶11 小时前
iOS MMKV原理整理总结:比UserDefaults快100倍的存储方案是如何炼成的?
算法·架构
星释11 小时前
Rust 练习册 100:音乐音阶生成器
开发语言·后端·rust
c***212911 小时前
Springboot3学习(5、Druid使用及配置)
android·学习
D_evil__11 小时前
[C++高频精进] 并发编程:线程基础
c++
风生u12 小时前
go进阶语法
开发语言·后端·golang
666HZ66612 小时前
C语言——黑店
c语言·开发语言
Gomiko12 小时前
JavaScript基础(八):函数
开发语言·javascript·ecmascript
云里雾里!12 小时前
力扣 209. 长度最小的子数组:滑动窗口解法完整解析
数据结构·算法·leetcode