#include<stdio.h>
#include <string.h>
#include <stdlib.h>
long DecimalToOctal(long num); //2.递归 -- 输入的数据不要超过8位,否则可能转换错误,受数据类型长度限制
char* ConvertStr_8(int n); //3.辗转相除法,数据位数可以很长,但是转换后的数据是字符串

int main()
{
	int Dnum,Onum;
//	char* num10_8;
	scanf("%d",&Dnum);
//	printf("%o\n",Dnum); //1.强制转换
	Onum=DecimalToOctal(Dnum);
	printf("%d\n",Onum);
	
//	num10_8=ConvertStr_8(Dnum);
//	printf("%s\n",num10_8);
//	free(num10_8);
	return 0;
}

long DecimalToOctal(long num)
{
	if(num<8) return num;
	return num%8+DecimalToOctal(num/8)*10;
}



char* ConvertStr_8(int n)
{
	char *result;
	char ch;
	int num,mod,i;
	int count = 1;
	num= n;
	while(num>=10)
	{
		num/=10;
		count++;
	}
	result=(char*)malloc(sizeof(char)*(count+3));
	count=0;
	while (n) 
	{
		mod = n % 8;
		result[count] = mod + '0'; //最先存到的是八进制数的最低位!
		count++;
		n = n / 8;
	}
	result[count]='\0';
	for(i=0;i<=(count-1)/2;i++) //在把字符串倒过来,把最高位放在首地址
	{
		ch=result[i];
		result[i]=result[count-1-i];
		result[count-1-i]=ch;
	}
	return result;
}


点赞(0)
 

0.0分

5 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 1 条评论

zyj 5年前 回复TA
这个讲解是最好的