分析
我一开始的想法是通过输入整数形式八进制来转换成十进制输出,后来发现用字符数组输入更方便。我这里就讲讲我用整型数据输入的转换思路:
我们都知道二进制由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