整数的N进制字符串表示

【问题描述】编写程序实现用把整数n转换成以b为基的b进制数。如果n为负数,则输出的字符串的第一个字符为 -。b为大于1小于37的任意自然数值。当b=2时,输出字符只可能是 0 和 1;当b=16时,输出字符串中可能含有字符为 0- 9,a-f(字母以小写输出)。b还可以是其它数值。比如输入n=33,b=17,则输出33的17进制值为"1g"。
【输入形式】控制台输入整数n和b,其中n可以为负数。n和b以空格分隔.
【输出形式】控制台输出转化后的字符串s.
【样例输入1】5 2
【样例输出1】101
【样例输入2】-8 8
【样例输出2】-10
【样例说明】5的二进制就是101
【评分标准】

#include <iostream>
#include <stack>
using namespace std;
void com (int x,int y,char a[])
{
    stack<int> s;
    while(x)
    {
        s.push(x%y);
        x=x/y;
    }
    while(!s.empty())
    {
        cout<<a[s.top()];
        s.pop();
    }
}
int main()
{
    char a[]={'0','1','2','3','4','5','6','7','8','9','0','a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'};
    int x,y;
    cin>>x>>y;
    if(x<0)
    {
        cout<<"-";
        com(-x,y,a);
    }
    else
        com(x,y,a);
    return 0;

}

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Linux C中将整数转换成二进制字符串是一项非常基本的操作。可以使用以下步骤来完成这个过程: 1. 定义一个字符数组来存储二进制字符串,数组长度要足够长以存储整数的所有二进制位。 2. 定义一个变量来存储整数。 3. 使用位运算符将整数的每个二进制位与1进行“与运算”,可以确定每个二进制位是否为1。将结果存储在字符数组的对应位置。 4. 将整数右移一位,并重复第3步。这个过程需要循环,直到整数为0。 5. 字符数组中存储的二进制字符串是从右到左存储的,需要将其反转以获得正确的二进制字符串。 下面是一个简单的示例代码: ``` #include <stdio.h> #include <string.h> #define MAX_LEN 32 void intToBin(int num, char* binStr) { int i = 0; while(num > 0) { binStr[i++] = (num % 2 == 1) ? '1' : '0'; num >>= 1; } binStr[i] = '\0'; strrev(binStr); } int main() { int num = 10; char binStr[MAX_LEN]; intToBin(num, binStr); printf("%d in binary is %s\n", num, binStr); return 0; } ``` 在这个例子中,函数`intToBin`将`num`转换为二进制字符串,并将结果存储在`binStr`中。函数`strrev`用于反转字符串。在`main`函数中,我们将整数10转换为二进制字符串并打印出来。输出结果为`10 in binary is 1010`。 在实际应用中,还需要进行一些特殊处理来处理整数为负数的情况以及处理二进制字符串的前导0。但是,以上的方法已经可以用来实现一个基本的整数转二进制字符串的功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值