九度OJ 1138:进制转换 (进制转换)

时间限制:1 秒

内存限制:32 兆

特殊判题:

提交:2388

解决:935

题目描述:

将一个长度最多为30位数字的十进制非负整数转换为二进制数输出。

输入:

多组数据,每行为一个长度不超过30位的十进制非负整数。
(注意是10进制数字的个数可能有30个,而非30bits的整数)

输出:

每行输出对应的二进制数。

样例输入:
0
1
3
8
样例输出:
0
1
11
1000
来源:
2008年北京大学软件所计算机研究生机试真题

思路:

并不难的进制转换题,注意0的处理。


代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>
 
#define LEN 30
#define I 9 
#define N ( (LEN%I > 0) ? (LEN/I+1) : (LEN/I) )
#define M (I*N)
 
int divide2(int *a)
{
    int i, result;
    for (i=0; i<N; i++)
    {
        //printf("=======a[%d] = %d\n", i, a[i]);
        if (i < N-1)
            a[i+1] += (a[i] % 2) * pow(10, I);
        else
            result = a[i] % 2;
        a[i] /= 2;
        //printf("=======a[%d] = %d\n", i, a[i]);
    }
    return result;
}
 
int isZero(int *a)
{
    int i, iszero = 1;
    for (i=0; i<N; i++)
    {
        if (a[i] != 0)
        {
            iszero = 0;
            break;
        }
    }
    return iszero;
}
 
int main(void)
{
    int a[N];
    char s[M+1], s2[M*4+1], tmpInt[I+1];
    int i, len;
 
    while (scanf("%s", s) != EOF)
    {
        len = strlen(s);
        for (i=len-1; i>=0; i--)
            s[M-len+i] = s[i];
        for (i=0; i<M-len; i++)
            s[i] = '0';
        s[M] = '\0';
        //printf("s = %s\n", s);
 
        for (i=0; i<N; i++)
        {
            strncpy(tmpInt, s+i*I, I);
            tmpInt[I] = '\0';
            //printf("tmpInt = %s\n", tmpInt);
            a[i] = atoi(tmpInt);
            //printf("a[%d] = %d\n", i, a[i]);
        }
 
        i=0;
        do
        {
            s2[i++] = divide2(a)+'0';
            //for (int j=0; j<N; j++)
            //  printf("a[%d] = %d\n", j, a[j]);
            //printf("iszero = %d\n", isZero(a));
        } while (!isZero(a));
        s2[i] = '\0';
 
        len = strlen(s2);
        for (i=len-1; i>=0; i--)
            printf("%c", s2[i]);
        printf("\n");
    }
 
    return 0;
}
/**************************************************************
    Problem: 1138
    User: liangrx06
    Language: C
    Result: Accepted
    Time:90 ms
    Memory:920 kb
****************************************************************/


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值