『壹』 c語言中怎麼把16進制轉換成bcd碼

void HextoBCD(u8 *pBuff,u8 len) //十六進制轉為BCD碼
{
u8 i,temp;
for(i=0;i<len;i++)
{
temp=pBuff[i]/10;
time[i]=pBuff[i]%10+temp*16;
}
}

『貳』 8421BCD碼在c語言中的表示

樓上個哥們確信這個是一種二進製表示方法?據我淺薄的計算機知識了解:好像2進制好像只有0和1吧?這個16進制的代碼……當然你可以在變數聲明時直接定義
int n=138550221;
這樣就行了,在輸出時採用%X輸出;
你可以直接用計算器計算這個16進制數所對應的10進制數

『叄』 c語言bcd碼轉十進制

不知道我的理解對不對,這個問題,就是把一個整數還原成16進制數的表示方式,版而這個十六權進制數實際上表示的就是十進制數,所以我們只要把輸入的數轉換成十六進製表示就行了,但是有一個問題,其實需要注意的就是輸入的時候10-15
其實是不能輸入了,因為剛好就是A-F,所以不妨讓輸入值>=16
<=15
對於這個范圍的數
其實只要兩步就行了,第一,除以16取余數,對應的是各位上的數,除以16取整數商,對應的就是十位數,應該這樣就可以
void
main(){
int
a;
cin>>a;
if(a<16||a>153)cout<<"不符合輸入規則"<<endl;
else{
int
c=a%16;
int
b=a/16;
int
abc=
b*10+c;
cout<<abc<<endl;
}
}

『肆』 利用C語言 將BCD碼轉成二進制輸出的程序

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#defineINPUT_BCD_MAX_LENGTH10
intmain(void)
{
//
charbcd[INPUT_BCD_MAX_LENGTH];
char*bin=NULL;
chart_bin[6];
inti,j,q,r,t,bcd_len,bin_len;
printf("Pleaseenterthedecimalcode:");
scanf("%s",bcd);

bcd_len=strlen(bcd);
bin_len=bcd_len*6+1;
bin=(char*)malloc(bin_len);
memset(bin,0,bcd_len*6+1);
for(i=0;i<bcd_len;i++)
{
/*把字元轉換為數字*/
q=bcd[i]-'0';
//將每個十進制轉換為四位二進制
for(j=0;j<4;j++)
{
t=q/2;
r=q%2;
q=t;
if(q==0&&r!=1)
{
t_bin[j]='0';
}
else
{
//把數字轉換為字元
t_bin[j]=r+'0';
}
}
t_bin[j]='';
t_bin[j+1]='';
strrev(t_bin);
strcat(bin,t_bin);
}

printf("BCDcodeddecimal: %s ",bin);
free(bin);
bin=NULL;

system("pause");
return0;
}

『伍』 c語言bcd進制轉碼程序問題


voidshowbit(intn)
{
if(n>1){
showbit(n/2);
printf("");
}
printf("%d",n%2);
}
voidshowoct(intn)
{
if(n>7){
showoct(n/8);
printf("");
}
printf("%d",n%8);
}
voidshowhex(intn)
{
if(n>15){
showhex(n/16);
printf("");
}
printf("%d",n%16);
}
intmain()
{
inta;
printf("inputanum:");
scanf("%d",&a);
showbit(a);
printf(" ");
showoct(a);
printf(" ");
showhex(a);
printf(" ");
}


鍵盤抄輸入十進制整數,轉二進制八進制十六進制,希望會對你有所幫助

『陸』 c語言bcd碼相加

特別看中速度的話可以做個256×256的表格,查表計算

『柒』 如何用c語言實現bcd碼轉十六進制數比如BCD碼5(0101),怎麼轉成0x05

#include<stdio.h>
#include<string.h>
int main()
{
char a[20],b[5];
int i,result = 0,k = 1,j = 0;
printf("輸入一個二進制數:\n");
gets(a);
for(i = strlen(a)-1;i >= 0;i --)
{
if(a[i] == '1') result += 1 << (k-1); //如果是1,用1*位權
if(k == 4 || i == 0) //每四位計算一次結果(result)。
//如果到了最高位(i==0)不足四位(比如100 0000),也計算
{
switch(result)
{
case 10: b[j++]='A';break; //大於等於十轉化成字母
case 11: b[j++]='B';break;
case 12: b[j++]='C';break;
case 13: b[j++]='D';break;
case 14: b[j++]='E';break;
case 15: b[j++]='F';break;
default: b[j++]=result + '0';break;
}
result = 0; //結果清零
k = 0; //表示位權的K清零
}
k ++; // 初始位權為1
}
b[j] = '\0';
printf("結果是:\n");
for(i = strlen(b)-1;i >= 0;i --)
printf("%c",b[i]);
printf("\n");
return 0;
}

『捌』 用c語言十六進制 bcd碼

BCD難道還有什麼位數限制?
一般是把16進制先轉換成10進制,由10進制數決定BCD的位數。

『玖』 c語言怎麼把「abc」變成「bcd"

沒有必要轉換為int,然後再轉換回來,直接加1即可。

//---------------------------------------------------------------------------

#include <stdio.h>
#include <string.h>

void ne(char *a)
{
int i,len=strlen(a);
for (i = 0; i<len; i++)
a[i]++;
}
int main(void)
{
char str[80];
scanf("%s",str);
ne(str);
printf("%s\n",str);
return 0;
}
//---------------------------------------------------------------------------