1. 程式人生 > >P1017 進位制轉換 (負進位制轉換)

P1017 進位制轉換 (負進位制轉換)

和平常的轉化差不多

加多一步

如果餘數 < 0, 那麼餘數減去除數(此時除數是負),商數加1 

#include<cstdio>
#define _for(i, a, b) for(int i = (a); i <= (b); i++)
using namespace std;

void cal(int n, int m)
{
	if(n == 0) return;
	int p = n % m;
	n /= m;
	if(p < 0) p -= m, n++;
	cal(n, m);
	if(p <= 9) printf("%d", p);
	else printf("%c", p - 10 + 'A');
}

int main()
{
	int n, m;
	scanf("%d%d", &n, &m);
	printf("%d=", n);
	cal(n, m);
	printf("(base%d)\n", m);
	return 0;
}