⑴ 怎樣用c語言編寫一個程序將輸入的十進制數轉化成16進制
你可以設置一個字元串數組
char
HEX[16]
=
{'0',
'1',
'2',
3',
'4',
'5',
'6',
'7',
'8',
'9',
'A',
'B',
'C',
'D',
'E',
'F'}
以後你得出的數字,比如余數y是10,那麼HEX[y]列印出來就是A了
例子(現寫的)
int
now;
int
res[100];//答案
int
c
=
0;//位數
輸入到now;
while
(now
>
0)
{
res[c]
=
now
%
16;
now
=
now
/
16;
c++;
}
輸出是:
for
(i
=
0;
i
<
c;
i++)
{
輸出
HEX[res[i]];
}
演算法的精髓都給你啦,好好理解吧
/**********************************************
****************
補充
*****************
**********************************************/
改你的代碼
#include
"stdio.h"
void
main()
{
char
HEX[16]
=
{'0',
'1',
'2',
3',
'4',
'5',
'6',
'7',
'8',
'9',
'A',
'B',
'C',
'D',
'E',
'F'};
//<----------------這里加了
int
num;
printf("請輸入一個十進制整數:");
scanf("%d",&num);
int
a[10];
//<----------------這里改了
int
i=0;
int
yushu;
while(num>0)
{
yushu=num%16;
a[i]=yushu;
num=num/16;
i++;/*關鍵的就在這里,這後面書上寫的要用SWITCH,但是我用不好,請各位大蝦指教*/
}
printf("轉化為十六進制的數為:");
for(;i>=0;i--)//倒序輸出
{
printf("%c",HEX[a[i]]);
//<----------------這里改了
}
printf("\n");
}
⑵ c語言怎樣定義並輸入一個16進制數
1、C/C++規定,16進制數必須以 0x開頭。比如 0x1表示一個16進制數,而1則表示一個十進制,0xff,0xFF,0X102A,等等.其中的x不用區分大小寫。
C/C++中,10進制數有正負之分。比如12表示正12,而-12表示負12。但8進制和16進制只能表達無符號的正整數,如果在代碼中寫-0xF2,C/C++並不把它當成一個負數。
2、以下是一些用法示例:
int a = 0x100F; //用一個十六進制數給變數a賦值
int b = 0x70 + a; //用一個十六進制數+變數a的值給變數b賦值
⑶ 求c語言將十進制數轉換為16進制的函數
c語言將十進制數轉換為16進制的函數:
#include<stdio.h>
main()
{
int u10;
char u16[10];
int w=0,a,b,i;
printf("請輸入一個數字-->");
scanf("%d",&u10);
if(u10==0)
{
u16[0]='0';
w++;
}
else
{
a=u10;
while(a)
{
b=a%16;
if(b<10)
{
u16[w]='0'+b;
}
else
{
u16[w]='A'+b-10;
}
a=a/16;
w++;
}
}
printf("
");
printf("%d(10)轉換為16進制數字為:",u10);
for(i=w-1;i>=0;i--)
{
printf("%c",u16[i]);
}
printf("
");
}
(3)c語言16進制演算法教程擴展閱讀:
十進制數轉換為二進制數方法
十進制數轉換為二進制數時,由於整數和小數的轉換方法不同,所以先將十進制數的整數部分和小數部分分別轉換後,再加以合並。
1. 十進制整數轉換為二進制整數 十進制整數轉換為二進制整數採用"除2取余,逆序排列"法。具體做法是:用2去除十進制整數,可以得到一個商和余數;再用2去除商,又會得到一個商和余數,如此進行,直到商為零時為止,然後把先得到的余數作為二進制數的低位有效位,後得到的余數作為二進制數的高位有效位,依次排列起來。
2.十進制小數轉換為二進制小數
十進制小數轉換成二進制小數採用"乘2取整,順序排列"法。具體做法是:用2乘十進制小數,可以得到積,將積的整數部分取出,再用2乘餘下的小數部分,又得到一個積,再將積的整數部分取出,如此進行,直到積中的小數部分為零,或者達到所要求的精度為止。
然後把取出的整數部分按順序排列起來,先取的整數作為二進制小數的高位有效位,後取的整數作為低位有效位。
⑷ C語言如何定義一個16進制數
例:
int main(){
int a;
scanf("%p",&a);//16進制數輸入%p是輸入一個十六進制的數scanf("%llx",&a);也可以輸入十六進制並且比較正規
printf("%d",a);//十進制輸出%d是輸出一個十進制的數
printf("0x%x",a);//16進制輸出printf("%llX ",a);也可輸出一個十六進制數如果紅色部分大寫X則輸出十六進制為大寫字母否則小寫x輸出為小寫字母
}
參考:
最大數字是15位,沒有超過__int64能表達的最大數。__int64最大能表示16位十六進制數。所以直接進行加減就行了,需要注意的是輸入輸出的格式以及十六進製表達負數的時候顯示的是補碼。
#include<stdio.h>
int main(void)
{
long long a,b,result;
while(scanf("%llx%llx",&a,&b)!=EOF){
result=a+b;
if(result>=0)
printf("%llX ",result);
else
printf("-%llX ",-result);
}
return 0;
}
long long 類型格式字元:
(4)c語言16進制演算法教程擴展閱讀:
return用法:
作用是結束正在運行的函數,並返回函數值。return後面可以跟一個常量,變數,或是表達式。
函數的定義一般是這樣的,例如:
int a(int i)//第一個int是函數的返回值的類型,也就是return後面跟的值的類型,a是函數的名稱,括弧里的是傳遞給函數的參數,int是參數的類型,i是參數的名字
{
...//省略函數體內容
return b;//b必須與函數頭的返回值一致(此處為int型)
}
簡單函數舉例:
int addOne(int b)
{
return b+1;
}
該函數的作用是取得一個數,將這個數加上1,再將結果返回
調用時這樣:
int result=addOne(2);//此時result的值為3
函數括弧里的參數也可以為變數或能算出值的表達式
以上就是一個基本的函數,一般的函數都有返回值,也就是return後面跟的值,返回值可以為各種數據類型,如:int,float,double,char,a[](數組),*a(指針),結構或類(c++)
但不是所有函數都有返回值,如果某個函數無返回值,那麼返回值的位置則為「void」關鍵字,此時函數體中無返回值,即無return的值。但是函數中也可出現return,即一個空的return句子,其作用是使函數立即結束,如
void print()//括弧中為空表示無傳遞參數
{
printf("a");
printf("b");
return;//函數執行到此處結束
printf("c");
}//該函數只執行到return語句處,即屏幕上輸出的為"ab"
⑸ C語言中16進制的表示方法
16進制以0x開頭,後面跟數字0~9或字母A~F(小寫也可以),如:0x2D(16進制數2D)
⑹ C語言中16進制之間的加減乘除運算怎麼做
可以參考下面的代碼:
int a,b;
scanf("%x%x",&a,&b);
printf("%x %x ",a+b,a-b);
輸入:9 7
輸出:
10
2
(6)c語言16進制演算法教程擴展閱讀:
C語言fmod()函數:求x/y的余數(針對浮點數)
C語言acos()函數:求反餘弦
C語言asin()函數:求反正弦
C語言atan()函數:求反正切
C語言atan2()函數:求x/y的反正切值
if:條件語句,後面不需要放分號。(K&R時期引入)
else:條件語句否定分支(與if連用)。(K&R時期引入)
switch:開關語句(多重分支語句)。(K&R時期引入)
⑺ c語言、浮點數怎麼變成16進制
需要准備的材料分別有:電腦、C語言編譯器。
1、首先,打開C語言編譯器,新建一個初始.cpp文件,例如:test.cpp。
⑻ 在C語言中如何將10進制轉換成16進制
根據10進制轉換為16進制的規則,編寫C語言程序將10進制數轉換為16進制數。
具體實現方法可參考如下程序:
#include<stdio.h>
voidmain()
{
inti,x;//x表示欲轉換的10進制數
intdata[10],index=0;//data數組存放轉換後的16進制數,index表示下標
scanf("%d",&x);//接受欲轉換的10進制數
for(i=0;i<10;i++)//對數組data進行初始賦值操作
data[i]=0;
printf("%d對應的16進制為:",x);
//反復相除取余,並將余數存放在data數組中
while(x>0)
{
data[index]=x%16;
x=x/16;
index++;
}
//逆序輸出data數組中的元素,即為10進制數對應的16進制數
for(i=index-1;i>=0;i--)
printf("%d",data[i]);
printf(" ");
}
⑼ c語言中16進制轉換為十進制
最簡單的使用scanf()函數和printf()函數進行格式轉換,以16進制格式輸入,再以10進制格式輸出。
程序代碼如下:
#include<stdio.h>
int main()
{
int a=0;
int i=0;
scanf("%x",&a);
printf("%d",a);
return 0;
}
運行結果:
(9)c語言16進制演算法教程擴展閱讀:
scanf函數與printf函數的用法很像,都是以格式化的形式進行操作,例如上述程序中scanf("%x", &a);就是將輸入數據以十六進制格式存儲到變數a中。
"%x"是將字元串A23CD以十六進制形式輸入a中,如果將"%x"換成為"%d"的話,就是將字元串A23CD以十進制形式輸入a中,這顯然是錯誤的,因為將A23CD轉換為十進制的時候,無法解析A,CD等字元,所以得出的結果就是錯誤的。