Solotravel


私信TA

用户名:huodongquan

访问量:4649

签 名:

我该用怎样的速度才能和你相遇?

等  级
排  名 5072
经  验 1596
参赛次数 0
文章发表 9
年  龄 0
在职情况 学生
学  校
专  业 电子信息工程

  自我简介:


#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分

7 人评分

  评论区

这个讲解是最好的
2019-10-05 11:20:15
  • «
  • 1
  • »