我是靠谱客的博主 要减肥背包,最近开发中收集的这篇文章主要介绍C语言每日练习之进制转换,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

分析

我一开始的想法是通过输入整数形式八进制来转换成十进制输出,后来发现用字符数组输入更方便。我这里就讲讲我用整型数据输入的转换思路:

我们都知道二进制由0和1组成,3位二进制组成在一起,就可以表示0-7这八个数,所以八进制实际上就是3位二进制的组合(同理十六进制是4位二进制的组合),C语言的位运算操作的是二进制,算术运算针对的是十进制,所以,我们可以通过位运算求出八进制的每一位数(3位二进制为1位),然后通过算术运算符+,将他们加起来。和十进制运算不同的地方在于一个两位的十进制数的十位数要乘10加上个位数即一个两位十进制数,而八进制的两位数,高位只需要乘以8。

这题我们也可以偷个懒,让C编译器帮我们算,只需要三行即可实现转换:

int octal_num = 0;
scanf("%o", &octal_num);
printf("十进制:%dn", octal_num);

当然,不建议这样做。

至于用字符数组形式输入,那就更简单了,不用通过位运算取出八进制数每位数,具体实现见网上参考部分。

代码实现

#include <stdio.h>
/**
 * @brief 八进制转十进制
 * @param octal_number 八进制数
 * @return 十进制数
 */
int Octal_to_Decimal(int octal_number)
{
    int dec_number = 0;       //十进制返回值
    int negative = 0;         //负数标志
    if(octal_number < 0)      //负数判断
    {
        octal_number = -1 * octal_number;
        negative = 1;
    }
    while(octal_number != 0)
    {
        //高位之和乘8再加上低3位,低3位即八进制最低位
        dec_number = dec_number * 8 + (octal_number & 0x7) ;
        octal_number >>= 3;    //右移3位
    }
    if(negative)
        return -1 * dec_number;
    return dec_number;
}
#define FIRST  //使用第一种方法,注释掉此行则使用第二种方法
int main()
{
    int octal_num = 0;
#ifdef FIRST
    printf("输入一个八进制数n");
    scanf("%o", &octal_num);
    printf("对应的十进制为%dn", Octal_to_Decimal(octal_num));

#else
    /* 偷懒法 */
    puts("八进制:");
    scanf("%o", &octal_num);
    printf("十进制:%dn", octal_num);
#endif
    return 0;
}

运行结果

网上参考

//  Created by www.runoob.com on 15/11/9.
//  Copyright © 2015年 菜鸟教程. All rights reserved.
//   https://www.runoob.com/cprogramming/c-exercise-example82.html  
#include<stdio.h>
#include<stdlib.h>
int main()
{
    int n=0,i=0;
    char s[20];
    printf("请输入一个8进制数:n");
    gets(s);
    while(s[i]!=''){
        n=n*8+s[i]-'0';
        i++;
    }
    printf("刚输入的8进制数转化为十进制为n%dn",n);
    return 0;
}

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注靠谱客的更多内容!

最后

以上就是要减肥背包为你收集整理的C语言每日练习之进制转换的全部内容,希望文章能够帮你解决C语言每日练习之进制转换所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(75)

评论列表共有 0 条评论

立即
投稿
返回
顶部