C語言Printf和Scan函式的使用方法

2021-03-04 09:44:40 字數 4118 閱讀 1284

一 printf()函式是格式化輸出函式, 一般用於向標準輸出裝置按規定格式輸出

資訊。在編寫程式時經常會用到此函式。printf()函式的呼叫格式為:

printf("《格式化字串》", 《參量表》);

其中格式化字串包括兩部分內容: 一部分是正常字元, 這些字元將按原

樣輸出; 另一部分是格式化規定字元, 以"%"開始, 後跟乙個或幾個規定字元,

用來確定輸出內容格式。

參量表是需要輸出的一系列引數, 其個數必須與格式化字串所說明的輸出

引數個數一樣多, 各引數之間用","分開, 且順序一一對應, 否則將會出現意想

不到的錯誤。

格式化字串的格式是:

%[標誌][輸出最小寬度][.精度][長度]格式字元

1. 標誌:標誌字元為-、+、#、空格四種,其意義下表所示:

標誌意義

- 結果左對齊,右邊填空格

+ 輸出符號(正號或負號)

空格輸出值為正時冠以空格,為負時冠以負號

# 對c,s,d,u類無影響;對o類,在輸出時加字首o;對x類,在輸出時加字首0x;對e,g,f 類當結果有小數時才給出小數點(??????)

例1:#include

main()

_執行結果

a=100

a= 100

a=100

a=+100

a= 100

a=0144

a=0x64

b=123.254997 (?????)

2.輸出最小寬度:用十進位制整數來表示輸出的最少位數。(至少要輸出這麼多位!)

若實際位數多於定義的寬度:則按實際位數輸出。

若實際位數少於定義的寬度:則右對齊,左邊留空。

有負號,左對齊,右邊留空

表示寬度的數字以0開始,則右對齊,左邊留空。

例2 #include

main()

_執行結果:

a=3456

a= 3456

a=3456

a=0000003456

a=3456

3.精度:精度格式符以「.」開頭,後跟十進位制整數。意義是:

如果輸出數字,則表示小數的位數;若實際位數大於所定義的精度數,則四捨五入。若不足則補0;

如果輸出的是字元,則表示輸出字元的個數;若實際位數大於所定義的精度數,則截去超過的部分。

例3:#include

main()

_執行結果:

12.346 //四捨五入到小數點後三位

12.345600000 //不足補0

abcabcdefg

4.長度:長度格式符為h,l兩種,h表示按短整型量輸出,l表示按長整型量輸出?????

5.turbo c2.0提供的格式字元如下:

符號作用

%c 單個字元

%d 十進位制有符號整數

%e 以「科學記數法」的形式輸出十進位制的浮點數如2.451e+02

%f 輸出十進位制浮點數,不帶域寬時,保留6位小數

%g 選用e或f格式中較短的乙個輸出十進位制浮點數,不輸出無效零

%0 無輸出無符號八進位制整數

%p 指標的值

%s 輸出字串

%u 輸出無符號十進位制整數

%x, %x 輸出無符號十六進製制整數 (不輸出字首ox)

2. 一些特殊規定字元

字元作用

換行f 清屏並換頁

回車tab符

xhh 表示乙個ascii碼用16進表示,

其中hh是1到2個16進製制數

使用這些轉義字元時不需要加上%,可單獨使用!

由本節所學的printf()函式, 並結合上一節學習的資料型別, 編制下面的程

序, 以加深對turbo c2.0資料型別的了解。

例1#include

#include

int main()

其他需要注意的一些問題:

1.如果用浮點數表示字元或整型量的輸出格式, 小數點後的數字代表最大寬度,

小數點前的數字代表最小寬度。

例如: %6.9s 表示顯示乙個長度不小於6且不大於9的字串。若大於9, 則第9個字元以後的內容將被刪除。

2.使用printf函式時還要注意乙個問題,那就是輸出表列中的求值順序。不同的編譯系統不一定相同,可以從左到右,也可從右到左。

turbo c是按從右到左進行的。請看下面兩個例子:

例1main()

執行結果87

78-7-8

例2main()

執行結果:98

89-8-9

這兩個程式的區別是用乙個printf語句和多個printf 語句輸出。但從結果可以看出是不同的。為什麼結果會不同呢?

就是因為printf函式對輸出表中各量求值的順序是自右至左進行的。在第一例中,先對最後一項「-i--」求值,結果為-8,然後i自減1後為7。 再對「-i++」項求值得-7,然後i自增1後為8。

再對「i--」項求值得8,然後i再自減1後為7。再求「i++」項得7,然後i再自增1後為8。 再求「--i」項,i先自減1後輸出,輸出值為7。

最後才求輸出表列中的第一項「++i」,此時i自增1後輸出8。

但是必須注意,求值順序雖是自右至左,但是輸出順序還是從左至右,因此得到的結果是上述輸出結果。

二 scan函式

數 scanf()函式是格式化輸入函式, 它從標準輸入裝置(鍵盤) 讀取輸入的資訊。

其呼叫格式為:

scanf("《格式化字串》", 《位址表》);

格式化字串包括以下三類不同的字元;

1. 格式化說明符: 格式化說明符與printf()函式中的格式說明符基本相同。

2. 空白字元: 空白字元會使scanf()函式在讀操作中略去輸入中的乙個或多

個空白字元。

3. 非空白字元: 乙個非空白字元會使scanf()函式在讀入時剔除掉與這個非

空白字元相同的字元。

注意:(1)位址表是需要讀入的所有變數的位址, 而不是變數本身:

----如果是一般的變數,通常要在變數名前加上"&";但輸出時是用變數名

----如果是陣列,用陣列名就代表了該陣列的首位址;輸出時也是用陣列名

----如果是指標,直接用指標名本身,不要加上「*」;輸出時也用該指標即可。

例1:各個變數的位址之間同","分開。

main()

(2)scanf函式中是否包含空白/非空白字元導致輸入格式的不同

如:scanf("%d,%d",&i,&j); scanf中有,所以輸入的格式應該是5,6==>i=5,j=6

scanf("%d%d",&i,&j); 可以用空格或回車來分隔兩個輸入如 5 6==>i=5,j=6

scanf("%d %d",&i,&j); 同上

(3) 實際使用scanf()函式時存在乙個問題, 下面舉例進行說明:

當使用多個scanf()函式連續給多個字元變數輸入時, 例如:

main()

執行該程式, 輸入乙個字元a後回車 (要完成輸入必須回車), 在執行scanf

("%c", &c1)時, 給變數c1賦值"a", 但回車符仍然留在緩衝區內, 執行輸入語句

scanf("%c", &c2)時, 變數c2輸出的是一空行, 如果輸入ab後回車, 那麼輸出結

果為: c1 is a, c2 is b。

要解決以上問題, 可以在輸入函式前加入清除函式fflush()( 這個函式的使

用方法將在本節最後講述)。修改以上程式變成:

#include

main()

在輸入字元資料時,若格式控制串中無非格式字元,則認為所有輸入的字元均為有效字元。

例如:scanf("%c%c%c",&a,&b,&c);

輸入為:d e f

則把'd'賦予a, ' ' 賦予b,'e'賦予c。

只有當輸入為: def

時,才能把'd'賦於a,'e'賦予b,'f'賦予c。

如果在格式控制中加入空格作為間隔,

如:scanf ("%c %c %c",&a,&b,&c);

則輸入時各資料之間可加空格。

例4main()

由於scanf函式"%c%c"中沒有空格,輸入m n,結果輸出只有m。而輸入改為mn時則可輸出mn兩字元。

(4)格式字串的一般形式為:

%[*][輸入資料寬度][長度]型別

c語言printf控制格式大全

printf的格式控制的完整格式 0 m.n l或h 格式字元 下面對組成格式說明的各項加以說明 表示格式說明的起始符號,不可缺少。有 表示左對齊輸出,如省略表示右對齊輸出。0 有0表示指定空位填0,如省略表示指定空位不填。m.n m指域寬,即對應的輸出項在輸出裝置上所佔的字元數。n指精度。用於說明...

c語言printf輸出格式大全

1 轉換說明符 a a 浮點數 十六進製制數字和p p 記數法 c99 c字元 d有符號十進位制整數 f浮點數 包括float和doulbe e e 浮點數指數輸出 e e 記數法 g g 浮點數不顯無意義的零 0 i有符號十進位制整數 與 d相同 u無符號十進位制整數 o八進位制整數 e.g.01...

c語言競賽和演算法總結

演算法集適合演算法競賽或興趣了解 2015 2 9 計算機徐一粟 1.10進製轉2進製4 2.啤酒和飲料5 3.圓的面積5 4.切麵條6 5.01字串7 6.字母圖形8 7.求n 個數的最大值,最小值,和9 8.楊輝三角形10 9.2個數 公約數,公倍數 三種演算法1110.歌手大獎賽16 11.輸...