笔试面试之 任意数制转换

本文提供了一个C++程序示例,用于将十进制整数转换为2到36之间的任意进制数,并通过控制台输出转换结果。该程序包括错误检查和处理逻辑,确保输入的有效性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include<iostream>      

 

using namespace std;      

 

int NumConvert(int n,int k)      

{      

    long long t = n;      

    if(k < 2 || k > 36) return -1;      

    if(t == 0)      

    {      

        printf("0");      

        return 0;      

    }      

    if(t < 0)      

        printf("-"), t = -t;      

    char buf[100];      

    int i,j;      

    for(i=0;i<100 && t>0;i++,t/=k)      

    {      

        j = t % k;      

        if(j < 10)    

            buf[i] = '0'+j;      

        else    

            buf[i] = 'A'-10+j;      

    }      

    for(;i>0;)   

        printf("%c/n",buf[--i]);      

    return 0;      

}     

 

 

int main(void)   

{   

    int n,k;   

    while(cin>>n>>k)   

        NumConvert(n,k) ;   

    return 0;   

 

本文来自优快云博客,转载请标明出处:http://blog.youkuaiyun.com/nash635/archive/2010/04/15/5491169.aspx

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值