C语言 进制转换
我一开始的想法是通过输入整数形式八进制来转换成十进制输出,后来发现用字符数组输入更方便。我这里就讲讲我用整型数据输入的转换思路:
我们都知道二进制由0和1组成,3位二进制组成在一起,就可以表示0-7这八个数,所以八进制实际上就是3位二进制的组合(同理十六进制是4位二进制的组合),C语言的位运算操作的是二进制,算术运算针对的是十进制,所以,我们可以通过位运算求出八进制的每一位数(3位二进制为1位),然后通过算术运算符+,将他们加起来。和十进制运算不同的地方在于一个两位的十进制数的十位数要乘10加上个位数即一个两位十进制数,而八进制的两位数,高位只需要乘以8。
这题我们也可以偷个懒,让C编译器帮我们算,只需要三行即可实现转换:
int octal_num = 0; scanf("%o", &octal_num); printf("十进制:%d\n", 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("对应的十进制为%d\n", Octal_to_Decimal(octal_num)); #else /* 偷懒法 */ puts("八进制:"); scanf("%o", &octal_num); printf("十进制:%d\n", 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]!='\0'){ n=n*8+s[i]-'0'; i++; } printf("刚输入的8进制数转化为十进制为\n%d\n",n); return 0; }
总结
本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注编程宝库的更多内容!
冒泡排序(Bubble Sort),是一种计算机科学领域的较简单的排序算法。冒泡排序(这里只讨论从小到大排序)可以通过二种方式实现,分别是将最小值依次移动到头部和将最大值依次移动到尾部。 代码实现代码采用从数组头 ...