POJ-3191(负进制)

37 篇文章 0 订阅

负数进制和正数进制类似。对于负数进制,每次取的余数保证在0~-m-1之间。(例如m=-16,则余数应该在0~15)就可以直接输出。  所以用系统的“mod”运算符的时候必须注意检查是不是在该范围(可能在m+1~0),否则就调整。调整的方法是:
if 余数<0 then
begin
余数=余数-m;
商=商+1;
end;
#include <iostream>
#include <cstdio>
using namespace std;
const int maxn = 1000;
int bit[maxn];
int main()
{
    int n;
    while(cin >> n)
    {
        int len = 0;
        while(n)
        {
            int r = n % -2;
            int c = n / -2;
            if(r < 0)
            {
                c++;
                r += 2;
            }
            n = c;
            bit[len++] = r;
        }
        for(int i = len-1; i >= 0; i--)
        {
            printf("%d",bit[i]);
        }
        if(len == 0)
            printf("0");
    }
    return 0;
}

说一点负数取余的知识

取余的函数定义 a%b = a - (a/b)*b

所以例如-7%5 = -7 - (-1)*5 = -2

比如:

21 % 6 = 3;
21 % 7 = 0;
-21 % -8 = -5;
21 % -5 = 1;
21 / 6 = 3;
21 / 7 = 3;
-21 / -8 = 2;
21 / -5 = -4

余数符号与被除数符号一致

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值