微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

将整数转换为二进制

#include <stdio.h>
#include <limits.h>

#define MAXLINE 1000

void itob(int n, char s[], int b);
void reverse(char s[]);

int main(void)
{
    char s[MAXLINE];

    itob(INT_MIN, s, 16);
    printf(%d in base %d is %s.\n, INT_MIN, 16, s);
    itob(123, s, 10);
    printf(%d in base %d is %s.\n, 123, 10, s);
    itob(-321, s, 5);
    printf(%d in base %d is %s.\n, -321, 5, s);

    return 0;
}

void itob(int n, char s[], int b)
{
    int i, sign, remainder;
    char bases[] = 0123456789ABCDEFGHIJKLMnopQRSTUVWXYZ;

    if (b < 2 || b > 36)
        return;

    sign = n;
    i = 0;
    do {
        remainder = n % b;
        s[i++] = ((sign < 0) ? -remainder : remainder) + '0';
    } while (n /= b);
    if (sign < 0)
        s[i++] = '-';
    s[i] = '\0';
    reverse(s);
}

void reverse(char s[])
{
    int i, j;
    int tmp;

    for (j = 0; s[j] != '\0'; ++j)
        ;
    --j;

    for (i = 0; i < j; ++i, --j) {
        tmp = s[i];
        s[i] = s[j];
        s[j] = tmp;
    }
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐