2019秋_计导练习7 G

问题描述:
设计函数int numConvert(int number,int n,int m),用于将n进制的数number转化为m进制的数并返回,其中2<=n<=10,2<=m<=10。例如将二进制数110转化为三进制时,即调用numConvert(110,2, 3),函数返回值为20。可以推断出,返回值肯定在int型变量范围内。

输入与输出要求:
输入三个正整数number、n和m,三个整数的意义如题目叙述。输出转化后的结果。

程序运行效果:
Sample 1:
110 2 3↙
20
Sample 2:
666666 9 10↙
398580

#include<stdio.h>
#include<math.h>
int numConvert(int number,int n,int m);
void f(int sum,int n);
int main() {
	int number,n,m;
	scanf("%d %d %d",&number,&n,&m);
	numConvert(number,n,m);
	return 0;
}
int numConvert(int number,int n,int m){
	int a1=number;
	int i,sum=0;
	for(i=-1;a1>0;i++){
		a1/=10;
	}
	for(a1=number;i>=0;i--){
		sum*=n;
		sum+=a1/pow(10,i);
		a1%=(int)pow(10,i); 
	}
	f(sum,m);
}
void f(int sum,int m){
	int r;
	r=sum%m;
	if(sum>=m){
		f(sum/m,m);
	}//利用递归函数反向计算
	printf("%d",r);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值