分析
我一开始的想法是通过输入整数形式八进制来转换成十进制输出,后来发现用字符数组输入更方便。我这里就讲讲我用整型数据输入的转换思路:
我们都知道二进制由0和1组成,3位二进制组成在一起,就可以表示0-7这八个数,所以八进制实际上就是3位二进制的组合(同理十六进制是4位二进制的组合),C语言的位运算操作的是二进制,算术运算针对的是十进制,所以,我们可以通过位运算求出八进制的每一位数(3位二进制为1位),然后通过算术运算符+,将他们加起来。和十进制运算不同的地方在于一个两位的十进制数的十位数要乘10加上个位数即一个两位十进制数,而八进制的两位数,高位只需要乘以8。
这题我们也可以偷个懒,让C编译器帮我们算,只需要三行即可实现转换:
1
2
3
|
int octal_num = 0; scanf ( "%o" , &octal_num); printf ( "十进制:%d\n" , octal_num); |
当然,不建议这样做。
至于用字符数组形式输入,那就更简单了,不用通过位运算取出八进制数每位数,具体实现见网上参考部分。
代码实现
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
#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; } |
运行结果
网上参考
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
// Created by www.runoob.com on 15/11/9. // Copyright © 2015年 菜鸟教程. All rights reserved. // <a href="https://www.runoob.com/cprogramming/c-exercise-example82.html">https://www.runoob.com/cprogramming/c-exercise-example82.html</a> #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; } |
总结
本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注服务器之家的更多内容!
原文链接:https://xiaohuisuper.blog.csdn.net/article/details/121087382