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),是一种计算机科学领域的较简单的排序算法。冒泡排序(这里只讨论从小到大排序)可以通过二种方式实现,分别是将最小值依次移动到头部和将最大值依次移动到尾部。 代码实现代码采用从数组头 ...