日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

C语言存储为2进制,浮点数的二进制存储形式及c语言验证

發布時間:2023/12/15 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C语言存储为2进制,浮点数的二进制存储形式及c语言验证 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

我們經常聽說浮點數,其實浮點數是和定點數對應的。定點數就是小數點固定的數,而且他的小數點在最右邊,所以定點數用來表示整數。

浮點數表示方法允許小數點的浮動,一個浮點數分為三個部分:第一部分是符號,可以是正數可以是負數;第二部分是小數點應該左移或右移的位移量;第三部分是小數點位置固定的定點表示法。

下面介紹常用的IEEE標準定義的浮點數的標準。

符號部分: 0表示正數 1表示負數

位移量部分:采用余127碼表示。在余碼系統中,正數和負數都用無符號數儲存,而且可以保持原有的大小關系,只需要將所有的數字整體右移。即該部分看做無符號整數,127表示0

126表示-1 128表示1

尾數部分:是將某數字化為1.xxxxxxx * 2^n的形式后的xxxxxx部分.小數點和其左邊的1并不存儲。

浮點數的存儲步驟:

1. 看符號位

2.將數字轉化成二進制

3.將二進制規范化為 1.xxxxxxxx*2^n

4. 將n轉化為指數(加上127) 尾數xxxx后面補零

5.寫出

下面舉幾個例子:

5.75的二進制表示

1. 是正數,因此符號位為0

2. 十進制轉化二進制 5.75 = 101.11(二進制)

3. 將二進制規范化:101.11 = 1.0111 * 2^2

指數部分為2 ?尾數部分為0111

4. 根據余127碼 指數部分為 2+127 = 129 = 10000001(二進制) 尾數部分后面補零

01110000000000000000000

5. 表示如下

0 10000001 01110000000000000000000

-161.875的二進制表示

1. 符號位為1 (負數)

2.轉化為二進制 161.875 = 10100001.111(二進制)

3.二進制規范化: 10100001.111 = 1.0100001111 * 2^7

4.指數部分E = 7+127 = 134 = 10000110(二進制) 尾數部分0100001111

5.表示如下

1 10000110 01000011110000000000000

1 10010100 00000000111000100001111表示為實數

1. 首位為1 是負數

2. 指數部分10010100 = 148 ?148-127

= 21

3. 尾數去規范化 1.00000000111000100001111

4.二進制為?1.00000000111000100001111 * 2^21

5. 十進制為2104378.75

6.該數字是 -2104378.75

c語言驗證

源代碼如下

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

#include

int main(void)

{

float fnum = 1;

int i;

int * p = (int

*)&fnum;

while (fnum

!= 0)

{

printf("input

a num: ");

scanf("%f",

&fnum);

for (i

= 31;

i >= 0;

i--)

{

printf("%d",

(*p

& (1

<< i)

? 1:

0));

}

printf("\n");

}

return 0;

}

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的C语言存储为2进制,浮点数的二进制存储形式及c语言验证的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。