C語言資料型別、變數的輸入和輸出、進位制轉換

GQH1000發表於2024-09-26
  scanf標準函式可以從鍵盤得到數字並記錄到儲存區裡,為了使用這個標準函式需要包含stdio.h這個標頭檔案

在scanf函式呼叫語句裡應該使用儲存區的地址表示儲存區;雙引號裡使用佔位符表示儲存區的型別,

在scanf函式呼叫語句裡儘量不要寫不是佔位符的內容,如果使用者輸入的格式和程式要求的格式不同

程式就無法獲得數字,可以在一條scanf函式呼叫語句裡獲得多個數字。

  一個位元組可以分成八段,每段可以用來記錄一個0或者1,

要想把一個數字記錄到一個位元組裡就必須首先拆分成8個0或者1,用一組0或者1表示數字的方法叫二進位制,

任何一個數字既可以用十進位制方式標誌也可以使用二進位制方式表示,計算機裡只能記錄用二進位制表示的數字

二進位制數字中每個位置有一個編號,最右邊位置的編號為0,向左依次遞增

二進位制數字中每個數位裡的1單獨代表一個數字,這個數字就是2的數位次方

二進位制數字中如果兩個相鄰數位的內容一樣,則左邊數位的內容是右邊數位內容的2倍

二進位制表示的非負數符合以上規則,二進位制數字加一的時候把編號為0位置開始的連續多個1變為0

把最右邊的0變為1,任何數字除以2並保留整數部分的結果相當於去掉最右邊二進位制數位的內容

二進位制表示的非負數轉換成十進位制的時候,只需要把每個數位的內容單獨轉換然後再把轉換結果求和

`0000	0011=2的1次方+2的0次方=2+1=3`

十進位制表示的非負數轉換成二進位制的方法,不停對原始數字進行除以2並保留整數部分的操作

得到一組數字,用每個數字除以2取餘得到一個數位的內容,把所有數位的內容從後向前倒序書寫就得到轉換結果

負數的二進位制和十進位制之間不能直接轉換,必須藉助相反數,轉換過程分三步,首先計算相反數,

然後把相反數進行轉換最後再次計算相反數

把二進位制數字每個數位的內容變成相反數字然後再加一得到相反數的二進位制。比如:

`-14

14

0000	1110

1111	0001

1111	0010(-14的二進位制)
`

有符號型別的二進位制數字中最左邊的數位叫做符號位,他的內容可以用來判斷數字是負數還是非負數。

符號位內容是0表示非負數,符號位內容是1表示數字是負數。比如:

`1100	1011

0011	0100+1=0011	0101=-53`

把二進位制的數字的 數位從右向左每三個分成一組,每組用一個0到7之間的數字替換

這個替換結果叫做數字的八進位制表示方式。比如:

`0100	1010				01	101	010			1	5	2=152(八進位制)`

可以在程式裡直接使用八進位制方式表示數字,這種數字必須以0做開頭

可以在printf函式呼叫語句裡使用%o做佔位符把數字的八進位制發表示方式顯示在螢幕上

把二進位制數字的數位從右向左每四個數位分成一組,每組用一個字元替換(用a到f之間的字母替換10到15之間的數字)

這個替換結果叫數字的十六進位制表示方法

`1100	1011			cb(十六進位制)
`

可以在程式裡使用十六進位制方式表示數字,這種數字必須以0x做開頭

可以在printf函式呼叫語句裡使用%x或%X做佔位符把數字的十六進位制表示方式顯示在螢幕上

用%x做佔位符的手數字裡的所有字母都是小寫的,用%X做佔位符的時候數字裡的所有字母都是大寫的

運算子代表了對數字的計算規則,根據運算子所需要配合的數字個數可以把運算子分為

單目運算子、雙目運算子和三目運算子。

C語言裡使用+、-、*和/表示加減乘除四則運算

如果參與除法計算的兩個數是整數;則計算結果只保留整數部分,C語言裡用%表示取餘數操作,

     賦值運算子用=表示,這個運算子可以把一個數字記錄到一個儲存區裡

     賦值語句可以當作數字使用,這個數字就是複製完成後左邊儲存區裡的數字

     可以在一條語句裡使用多個賦值運算子,這個時候首先計算**右邊**的賦值運算子

     大多數雙目運算子可以和賦值運算子合併成為複合賦值運算子,如:+=,/=等

     複合賦值運算子也要求左邊的內容可以代表儲存區,右邊的內容可以代表數字

     複合賦值運算子把雙目運算子的計算結果記錄到左邊的儲存區裡

     複合賦值運算子的優先順序和賦值運算子一樣低

自增運算子(++)和自減運算子(--)都是單目運算子,**這兩個運算子都必須和儲存區配合使用**

    他們可以把儲存區的內容加一或減一,他們都有兩種使用方法。

    一種是前操作(運算子寫在儲存區的前面);另一種是後操作(運算子寫在儲存區的後面)

    使用這兩個運算子編寫的表示式可以當作數字使用,前操作當作數字使用的時候是

    修改後的數字,後操作當作數字使用的時候是修改前的數字

    不要在一條語句裡對同一個變數多次進行自增或自減計算

邏輯運算子用來編寫邏輯表示式,邏輯表示式的結果只能是布林值

!是一個單目邏輯運算子,它用來計算一個布林值的相反值,這個運算子使用的時候應該寫在一個布林值的前面

雙目邏輯運算子包括==(等於)、!=(不等於)、<(小於)、 >(大於)>=(大於等於)和<=(小於等於)

最多包含一個雙目邏輯運算子的表示式叫做簡單邏輯表示式,

這種邏輯表示式在數學裡的結果和在C語言裡的結果一定相同

    在C語言裡編寫邏輯表示式的時候如果邏輯表示式裡包含多個雙目邏輯運算子

    就必須拆分成多個簡單邏輯表示式然後再合併

    可以使用與(&&)和或(||)把兩個邏輯表示式合併成一個如果兩個邏輯表示式裡有一個的結果是真

    則用或(||)連線以後結果就是真,如果兩個表示式裡有一個的結果是假則用與(&&)連線以後結果就是假

    與(&&)和或(||)都有短路特徵

   (如果前一個邏輯表示式的結果可以決定合併後邏輯表示式的結果就可以忽略後一個邏輯表示式)

練習:
男人身高減體重小於105算超重
女人身高減體重小於110算超重
gender(0代表女人,1代表男人)
height	身高
weight	體重
編寫邏輯表示式當超重的時候得到結果為真

```c
(gender &&(height-weight<105))||
(!gender &&(height-weight<110) )

練習:

編寫程式從鍵盤得到一個數字,判斷這個年份是不是閏年並把這個結果顯示在螢幕上

如果年份數字可以被4整除但不能被100整除就是閏年

如果年份可以被400整除也是閏年

/*
 *
 *編寫程式從鍵盤得到一個年份數字,判斷這個年份
 *是不是閏年並把結果顯示在螢幕上
 *如果年份數字可以被4整除但不能被100整除就是閏年
 *如果年份數字可以被400整除也是閏年
 *
 * */
#include<stdio.h>
int main(){
	int year=0;
	printf("請輸入一個年份:\n");
	scanf("%d",&year);
	int tmp=0;
	tmp=(!(year%4) && year%100) || !(year%400);
	printf("判斷結果是%d\n",tmp);
	return 0;
}

練習1:

點選檢視程式碼
/*
 *
 * 編寫程式從鍵盤得到一個浮點數
 * 把這個浮點數作為半經
 * 計算圓的周長
 * 並把結果顯示在螢幕上
 *
 * */
#include<stdio.h>
int main(){
	float r=0.0f;
	printf("請輸入一個圓的半經:\n");
	scanf("%g",&r);
	printf("圓的周長=%g\n",2*3.14*r);
	return 0;
}

練習2:

點選檢視程式碼
/*
 * 二進位制演示
 *
 * */
#include<stdio.h>
int main(){
	char ch=300;
	int num=ch;
	printf("num=%d\n",num);

	ch=128;
	num=ch;
	printf("num=%d\n",num);
	return 0;
}
練習3:
點選檢視程式碼
/*
 *
 * 八進位制和十六進位制演示
 *
 * */
#include<stdio.h>
int main(){
	char ch=0;
	int num=0; 
	printf("%d  0%o\n",0152,0152);
	printf("0x%x  0X%X\n",0xcb,0xcb);
	num=ch=300;
	printf("num=%d\n",num);
	num +=6;
	printf("num=%d\n",num);
	num *=2+3;
	printf("num=%d\n",num);
	return 0;
}
練習4:
點選檢視程式碼
/*
 *
 * 運算子演示
 *
 * */
#include<stdio.h>
int main(){
	int num=0,num1=0;
	num++;
	printf("num=%d\n",num);
	++num;
	printf("num=%d\n",num);
	num=10;
	num1=num++;
	printf("num=%d  num1=%d\n",num,num1);
	num1=++num;
	printf("num=%d  num1=%d\n",num,num1);
	return 0;
}
練習5:
點選檢視程式碼
/*
 *
 * 邏輯運算子演示
 *
 * */
#include<stdio.h>
int main(){
	int num=0;
	printf("3<7<5=%d\n",3<7<5);
	printf("!8=%d\n",!8);
	printf("3<7 && 7<5=%d\n",3<7&&7<5);
	1 || ++num;
	printf("num=%d\n",num);
	0 && ++num;
	printf("num=%d\n",num);

	return 0;
}

相關文章