C实现任意进制数的转化

简介: 版权声明:您好,转载请留下本人博客的地址,谢谢 https://blog.csdn.net/hongbochen1223/article/details/45246025 该实例要求使用C实现一个无符号整数到[2,16]进制数的转换。
版权声明:您好,转载请留下本人博客的地址,谢谢 https://blog.csdn.net/hongbochen1223/article/details/45246025

该实例要求使用C实现一个无符号整数到[2,16]进制数的转换。这个还是比较好想的,就是对该无符号整数不断的斤进制数d取余数,取商,一直做这样的运算,直到商为0为止,将所有的余数按照从后往前的顺序穿起来,就是转换后的进制数。

下面上我的代码:

#include <stdio.h>

/** 用于声明char数组的长度 **/
#define M (sizeof(unsigned int) * 8)

int trans(unsigned int m,int d,char s[]);

/**
 * @brief main  将一个无符号整数转换成任意d进制数(2 << d << 16)
 * @return
 */
int main(void)
{
    /**
     * 思路:将一个无符号整数m转换成任意d进制数,
     * 则可以将m除以d,将余数从char数组的最后一位
     * 向前保存,同时将商再除以d,以同样的方式进行处理
     * 最后得到的数组就是所对应的d进制数
     */

    unsigned int m;

    printf("Please enter the digits you want to transform:\n");
    scanf("%d",&m);

    char str[33];

    int i = 0;

    printf("The translate results are:\n");

    for(i = 2;i <= 16;i++){
        int nums = trans(m,i,str);

        printf("%d  =   ",m);
        int j = 0;
        for(j = 0;j < nums;j++){
            printf("%c",str[j]);
        }

        printf("(%d)\n",i);
    }

    return 0;
}

/**
 * @brief trans 用于对无符号整数转换
 * @param m 要被转换的数字
 * @param d 要被转换成的进制数
 * @param s 存放被转换后的进制数的数组
 * @return  返回转换后进制数的长度,也就是数组的长度
 */
int trans(unsigned int m,int d,char str[]){

    if(d < 2 || d > 16){
        //将s置为0
        str[0] = '\0';
        return 0;
    }

    /** 用于保存进制数 **/
    char digits[] = "0123456789ABCDEF";

    int i = M;
    int j = 0;
    char buf[M+1];
    /** 用于保存商 **/
    int s = m;

    buf[i] = '\0';

    //这里使用do...while
    do{
        buf[--i] = digits[s % d];
        s = s / d;
    }while(s);

    //对数组s进行赋值
    for(j = 0;(str[j]=buf[i])!= '\0';j++,i++);

    return j;
}

下面是我的运行结果截图:
这里写图片描述

目录
相关文章
给定一个正整数N,将其表示为数字1,3,7,15相加的形式输出。请编码找出使上述数字出现的总次数最少(每个数字可以重复使用)的组合。
给定一个正整数N,将其表示为数字1,3,7,15相加的形式输出。请编码找出使上述数字出现的总次数最少(每个数字可以重复使用)的组合。
|
2天前
两个方法实现 任意两个进制间相互转换
两个方法实现 任意两个进制间相互转换
10 0
两个方法实现 任意两个进制间相互转换
|
17天前
|
Java
JAVA输入任意一个数字,实现递减求和(计算任意整数n的和)
JAVA输入任意一个数字,实现递减求和(计算任意整数n的和)
13 0
|
1月前
|
算法
算法题 — 整数转二进制,查找其中1的数量
算法题 — 整数转二进制,查找其中1的数量
12 0
|
11月前
|
算法 Python
一日一技:如何统计一个数字的二进制值里面有多少个1
一日一技:如何统计一个数字的二进制值里面有多少个1
161 0
求两个数二进制中不同位的个数
题目内容:两个int(32)整数m和n的二进制表达中,有多少个位(bit)不同? 输入例子: 1999 2299 输出例子: 7
统计二进制中1的个数,,,写一个函数,返回参数二进制中1的个数 写一个代码判断一个数字是不是2的n次方
统计二进制中1的个数,,,写一个函数,返回参数二进制中1的个数 写一个代码判断一个数字是不是2的n次方
101 0
018.任意进制数的转换
018.任意进制数的转换
66 0
【c++】关于数值进制以及进制之间转化
【c++】关于数值进制以及进制之间转化
142 0
【c++】关于数值进制以及进制之间转化
求两个数的二进制数中不同位的个数
两个整数进行异或的结果是:相同位异或结果为0,不同位异或结果为1,进一步将问题转化为求这两个整数异或结果的二进制位为1的个数即所求两个数二进制数中不同位的合数。

热门文章

最新文章