1. c語言中如何將8進制字元串轉化成10進制

#include
#include
#include
int
zh(char
s[])
{
int
i,m,temp=0,n;
m=strlen(s);//十六進制是按字元串傳進來的,所以要獲得他的長度
for(i=0;i
='a'&&s[i]<='f')//十六進制還要判斷他回是不是在a-f或者a-f之間a=10。。答
n=s[i]-'a'+10;
else
if(s[i]>='a'&&s[i]<='f')
n=s[i]-'a'+10;
else
n=s[i]-'0';
temp=temp*16+n;
}
return
temp;
}
int
main()
{
char
s[10];
gets(s);
int
n=zh(s);
printf("%d\n",n);
return
0;
}

2. c語言中8進制轉10進制的演算法

你可以用char 定義 字元變數 得到的就是ASCII值了,也就是每一位的數

3. 8進制轉10進制的編程,用C語言的。請高手回答

你可以參考一下
#include<stdio.h>
r8(int a)
{
int i,j;
if(a==0)
return (0);
else
{
j=a%8;
i=a/8;
r8(i);
printf("%d",j);
}
}

int main()
{
int n;
printf("請輸入十進制數:");
scanf("%d",&n);
printf("轉換成八版進制數是權:");
r8(n);
printf("\n");
}

4. C語言中八進制076轉為十進制

八進制的076轉換成十進制=6*(8的0次方)+7*(8的1次方)=6*1+7*8=62

5. 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*/

6. 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);

}

(6)c語言8進制轉10進制擴展閱讀:

一、二進制數轉換

二進制數轉換成十進制數

由二進制數轉換成十進制數的基本做法是,把二進制數首先寫成加權系數展開式,然後按十進制加法規則求和。這種做法稱為"按權相加"法。例1105把二進制數110.11轉換成十進制數。

二、十進制數轉換為二進制數

十進制數轉換為二進制數時,由於整數和小數的轉換方法不同,所以先將十進制數的整數部分和小數部分分別轉換後,再加以合並。

1、十進制整數轉換為二進制整數十進制整數轉換為二進制整數採用"除2取余,逆序排列"法。具體做法是:用2去除十進制整數,可以得到一個商和余數;再用2去除商,又會得到一個商和余數,

如此進行,直到商為零時為止,然後把先得到的余數作為二進制數的低位有效位,後得到的余數作為二進制數的高位有效位,依次排列起來。

2、十進制小數轉換為二進制小數

十進制小數轉換成二進制小數採用"乘2取整,順序排列"法。具體做法是:用2乘十進制小數,可以得到積,將積的整數部分取出,再用2乘餘下的小數部分,又得到一個積,再將積的整數部分取出,如此進行,直到積中的小數部分為零,或者達到所要求的精度為止。

然後把取出的整數部分按順序排列起來,先取的整數作為二進制小數的高位有效位,後取的整數作為低位有效位。

7. 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

8. 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*/