当前位置:首页 » 编程语言 » 八进制转换为十进制c语言

八进制转换为十进制c语言

发布时间: 2022-04-20 01:47:44

‘壹’ c语言编程:八进制转换为十进制

#include<stdio.h>

void main()

{

char *p,s[6];int n;

p=s;

gets(p);

n=0;

while(*(p)!='')

{n=n*8+*p-'0';

p++;}

printf("%d",n);

}

(1)八进制转换为十进制c语言扩展阅读:

一、二进制数转换

二进制数转换成十进制数

由二进制数转换成十进制数的基本做法是,把二进制数首先写成加权系数展开式,然后按十进制加法规则求和。这种做法称为"按权相加"法。例1105把二进制数110.11转换成十进制数。

二、十进制数转换为二进制数

十进制数转换为二进制数时,由于整数和小数的转换方法不同,所以先将十进制数的整数部分和小数部分分别转换后,再加以合并。

1、十进制整数转换为二进制整数十进制整数转换为二进制整数采用"除2取余,逆序排列"法。具体做法是:用2去除十进制整数,可以得到一个商和余数;再用2去除商,又会得到一个商和余数,

如此进行,直到商为零时为止,然后把先得到的余数作为二进制数的低位有效位,后得到的余数作为二进制数的高位有效位,依次排列起来。

2、十进制小数转换为二进制小数

十进制小数转换成二进制小数采用"乘2取整,顺序排列"法。具体做法是:用2乘十进制小数,可以得到积,将积的整数部分取出,再用2乘余下的小数部分,又得到一个积,再将积的整数部分取出,如此进行,直到积中的小数部分为零,或者达到所要求的精度为止。

然后把取出的整数部分按顺序排列起来,先取的整数作为二进制小数的高位有效位,后取的整数作为低位有效位。

‘贰’ c语言八进制转10进制

由于指针p指向的字符必然是字符'0'~'7'(在main函数中已排除其他情况),且ascii码中字符'0'~'7'是连续的,所以对于
'0'-'0'==0
'1'-'0'==1
'2'-'0==2
...
'7'-'0'==7
必然成立
且此处已知字符串为八进制数,故此处n=n*8+*p-'0',8为权值
具体算法可解释为
0123==1*8*8+2*8+3
同理,还可推出对于任意N进制(N>=2)
123(N) == 1*N*N+2*N+3
如对于十进制数
123==1*10*10+2*10+3
十六进制数
0x123==1*16*16+2*16+3

‘叁’ C语言 八进制转十进制

字符串输入,然后每一个字符判断是不是0-7。

#include <stdio.h>
#include <conio.h>
#define MAX 100
int main()
{
char input[MAX],*p;
int i,data;

printf("Please enter an octal number:");
scanf("%s",input);

data=0;
p=input;
while(*p)
{
if (*p>='0' && *p<='7')
data=data*8+*p-'0';
else
{
printf("\"%s\" is not an octal number.\n",input);
break;
}
p++;
}
if (*p==0) /*从循环中退出*/
printf("%s(Oct)=%d(Dec)\n",input,data);

getch();
return 0;
}

当然scanf函数还可以这样用:
scanf("%[0-7]s",input); /*只要一碰到0-7以外的字符,立即截止输入到input*/

‘肆’ c语言 怎么把八进制转化为十进制

scanf("%c",&a[i]);%输入8进制数的字符串
if(a[i]<'\x30'||a[i]>='\x39') %输入的字符串是否数字0--7之间
break;
}
i--;
for(j=0;i>=0;i--,j++)
b+=(a[j]-48)*pow(8,i); /* 从把8进制数字符的ASIC码转换为十进制数
的0--7,然后从最低为位开始按各自的权展开
后相加,如(a3a2a1a0)8=a0*8^0+a1*8^1+a2*8^2+a3*8^3*/

‘伍’ 求八进制转化为十进制的c语言思路及编程

思路:对于所有的八进制数符,按乘权求和的思想就可以实现转化。

#include<stdio.h>

int main()

{int x=0,c;

printf("请输入一个八进制数:");

scanf("%c",&c);

while(c>='0'&&c<'8')

{x=x*8+c-'0';

scanf("%c",&c);

}

printf("十进制数为:%d ",x);

return 0;

}

‘陆’ 怎样用c语言把八进制数转化为十进制数

希望你的八进制数的类型是char
#include<stdio.h>
#include<string.h>
#include<math.h>

int main (void){
char x[10]={10000};//八进制的10000是十进制的4096.
int i,j;
double k=0,w=0;
j=strlen(x);//j用来判断用这个八进制数有多少位
for(i=0;i<strlen(x),i++)
{
k=(x[i]-48)*(pow(8,--j));
w+=k;
}
printf("%f\n",w);//显示十进制数
retrun 0 ;}
我是这个思路,希望对LZ有帮助。

‘柒’ C语言中八进制与十进制如何互相转化

先将十进制数转换为二进制数,然后就是从低位开始,每三位对应一位,不足补0
比如-32的代码是10101110(随便写的)
转换之后就是256,前面一个不足三位,在最前面补0
010
101
110
2
5
6

‘捌’ C语言中,八进制怎么转化成十进制

0177777(为8进制,即2的3次方),=0 177 777(从右到左三位为一段分开,计算出的结果挨着写在一起就是结果)=

‘玖’ C语言 将八进制字符转成十进制整数

n=*p-'0';//这一行已经把字符串的第一个字符处理了,所以下面是从下一个字符开始
p++;//所以要自加1

转化的过程是这样子的:

假设 s = '123'

fun(s)的运行过程如下:

n='1'-'0';//n=1
p++;//*p='2'

n=n*8+*p-'0';//n=n*8+'2'-'0'=1*8+2=10
p++;

n=n*8+*p-'0';//n=n*8+'3'-'0'=10*8+3=83,此时
p++;//此时*p=0;所以循环退出,返回n,结果就是83

‘拾’ C语言,如何把八进制变成十进制

比如说8进制的0234,转换过程就是2*8*8+3*8+4,简化成公式:8*(8*(2+0)+3)+4,*p-
‘0’是转化为整形字符的,希望能帮到你,谢谢

热点内容
查询密码单是什么 发布:2024-05-04 17:54:03 浏览:40
安卓系统不支持网络怎么办 发布:2024-05-04 17:49:31 浏览:127
oraclesqlserver 发布:2024-05-04 17:49:16 浏览:47
关爱脚本 发布:2024-05-04 17:43:47 浏览:421
linuxshellif 发布:2024-05-04 17:09:47 浏览:17
算法精英挑战赛 发布:2024-05-04 17:09:08 浏览:740
河南电力公众号绑定密码是多少 发布:2024-05-04 17:08:55 浏览:332
手机上怎么打开压缩文件 发布:2024-05-04 17:03:57 浏览:173
word加密文件如何解密 发布:2024-05-04 17:02:57 浏览:290
php源码本地测试 发布:2024-05-04 16:57:17 浏览:802