洛谷p1017 进制转换(负进制)

传送门:p1017
在这里插入图片描述

题目分析

题目难度:普及-/提高
负进制和正进制本质上是相同的,都有“模一个数取余,然后倒序输出”的特点。
但区别在于,整数n%(-2)时可能会出现余数mod为负的情况,那么就需要进行转换

设 n÷R = a……mod
此时的mod<0,则需要mod+|R|变为正数,即mod-R,则式子变为
n = a*R+mod-R+R = (a+1)*R+mod-R   所以接下来的n就变为了a+1
即n在n/=R的基础上,if(mod<0) n++,mod-=R;
AC代码
#include<bits/stdc++.h>
using namespace std;
//负进制 
char str[1000];    //用于储存数据,然后倒序输出,也可以采用递归形式省去数组空间消耗
int main()
{
	int n,R;
	int i = 0;
	cin>>n>>R;	cout<<n<<"=";
	while(n!=0)
	{
		int mod = n%R;    //R为负数! 
		n/=R;
		if(mod<0)      //如果mod为负,则要将其转化为正。
			{
				mod-=R;
				n++;		
			} 
		if(mod<=9) str[i++] = mod+'0';
		else str[i++] = mod+'A'-10;
	}
	str[i]='\0';
	int len = strlen(str);
	for(int i = len-1;i>=0;i--)
		cout<<str[i];
	cout<<"(base"<<R<<")";
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值