一、數據輸出語句
本小節介紹的是向標準輸出設備顯示器輸出數據的語句。在C++語言中,用cout和cin實現輸出和輸入,也可以調用C語言的輸出和輸入函數,所有的數據輸入/輸出都是由庫函數完成的。 因此都是函數語句。本小節先介紹printf函數和putchar函數。printf函數printf函數稱為格式輸出函數,其關鍵字最末一個字母f即為“格式”(format)之意。其功能是按用戶指定的格式, 把指定的數據顯示到顯示器屏幕上。在前面的例題中我們已多次使用過這個函數。
(一)printf函數調用的一般形式
printf函數是一個標準庫函數,它的函數原型在頭文件“cstdio”中。但作為一個特例,不要求在使用 printf 函數之前必須包含cstdio文件。printf函數調用的一般形式為:
printf(“格式控制字符串”,輸出表列);
其中格式控制字符串用於指定輸出格式。 格式控制串可由格式字符串和非格式字符串兩種組成。格式字符串是以%開頭的字符串,在%後面跟有各種格式字符,以說明輸出數據的類型、形式、長度、小數位數等。如“%d”表示按十進制整型輸出, “%c”表示按字符型輸出等。後面將專門給予討論。
非格式字符串在輸出時原樣照印,在顯示中起提示作用。 輸出表列中給出了各個輸出項, 要求格式字符串和各輸出項在數量和類型上應該一一對應。
void main
{
int a=88,b=89;
printf("%d %d\n",a,b); //第4行
printf("%d,%d\n",a,b); //第5行
printf("%c,%c\n",a,b); //第6行
printf("a=%d,b=%d",a,b); //第7行
}
本例中四次輸出了a,b的值,但由於格式控制串不同,輸出的結果也不相同。第四行的輸出語句格式控制串中,兩格式串%d 之間加了一個空格(非格式字符),所以輸出的a,b值之間有一個空格。第五行的printf語句格式控制串中加入的是非格式字符逗號,因此輸出的a,b值之間加了一個逗號。第六行的格式串要求按字符型輸出 a,b值。第七行中為了提示輸出結果又增加了非格式字符串。
(二)格式字符串
在C語言中格式字符串的一般形式為:
%[標誌][輸出最小寬度][.精度][長度]類型
其中方括號中的項為可選項。各項的意義介紹如下:
1.類型類型字符用以表示輸出數據的類型,其格式符和意義下表所示:
表示輸出類型的格式字符 格式字符意義
d 以十進制形式輸出帶符號整數(正數不輸出符號)
o 以八進制形式輸出無符號整數(不輸出前綴O)
x 以十六進制形式輸出無符號整數(不輸出前綴OX)
f 以小數形式輸出單、雙精度實數
e 以指數形式輸出單、雙精度實數
g 以%f%e中較短的輸出寬度輸出單、雙精度實數
c 輸出單個字符
s 輸出字符串
2.標誌
標誌字符為-、+、#、空格四種,其意義下表所示:
標誌格式字符 標 志 意 義
- 結果左對齊,右邊填空格
+ 輸出符號(正號或負號)空格輸出值為正時冠以空格,為負時冠以負號
# 對c,s,d,u類無影響;對o類, 在輸出時加前綴o 對x類,在輸出時加前綴0x;對e,g,f 類當結果有小數時才給出小數點
3.輸出最小寬度用十進制整數來表示輸出的最少位數。 若實際位數多於定義的寬度,則按實際位數輸出, 若實際位數少於定義的寬度則補以空格或0。
4.精度精度格式符以“.”開頭,後跟十進制整數。本項的意義是:如果輸出數字,則表示小數的位數;如果輸出的是字符,則表示輸出字符的個數;若實際位數大於所定義的精度數,則截去超過的部分。
main
{
int a=29;
float b=1243.2341;
double c=24212345.24232;
char c='h'
printf("a=%d,%5d,%o,%x\n",a,a,a,a); //第7行
printf("b=%f,%lf,%5.4lf,%e\n",b,b,b,b);
printf("c=%lf,%f,%8.4lf\n",c,c,c);
printf("d=%c,%
}
本例第七行中以四種格式輸出整型變量a的值,其中“%5d ”要求輸出寬度為5,而a值為15只有兩位故補三個空格。第八行中以四種格式輸出實型量b的值。其中“%f”和“%lf ”格式的輸出相同,說明“l”符對“f”類型無影響。“%5.4lf”指定輸出寬度為5,精度為4,由於實際長度超過5故應該按實際位數輸出,小數位數超過4位部分被截去。第九行輸出雙精度實數,“%8.4lf ”由於指定精度為4位故截去了超過4位的部分。第十行輸出字符量d,其中“%bc ”指定輸出寬度為8故在輸出字符p之前補加7個空格。
使用printf函數時還要注意一個問題, 那就是輸出表列中的求值順序。不同的編譯系統不一定相同,可以從左到右,也可從右到左。Dev C++ 按從右到左進行的。如下述形式:
void main{
int i=8;
printf("%d\n%d\n%d\n%d\n%d\n%d\n",++i,--i,i++,i--,-i++,-i--);
}
這個程序中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。但是必須注意, 求值順序雖是自右至左,但是輸出順序還是從左至右,因此得到的結果是:
8
7
-7
-8
(三)字符輸出函數
putchar 函數
putchar 函數是字符輸出函數, 其功能是在顯示器上輸出單個字符。其一般形式為: putchar(字符變量)
例如:
putchar('A'); 輸出大寫字母A
putchar(x); 輸出字符變量x的值
putchar('\n'); 換行 對控制字符則執行控制功能,不在屏幕上顯示。 使用本函數前必須要用文件包含命令:
#include<stdio.h>
#include <stdio.h>
void main{
char a='B',b='o',c='k';
putchar(a);putchar(b);putchar(b);putchar(c);putchar('\t');
putchar(a);putchar(b);
putchar('\n');
putchar(b);putchar(c);
}
二、數據輸入語句
C語言的數據輸入也是由函數語句完成的。 本節介紹從標準輸入設備—鍵盤上輸入數據的函數scanf和getchar。 scanf函數 scanf函數稱為格式輸入函數,即按用戶指定的格式從鍵盤上把數據輸入到指定的變量之中。
(一)scanf函數的一般形式
scanf函數是一個標準庫函數,它的函數原型在頭文件“stdio.h”中,與printf函數相同,C語言也允許在使用scanf函數之前不必包含stdio.h文件。scanf函數的一般形式為:
scanf(“格式控制字符串”,地址表列);
其中,格式控制字符串的作用與printf函數相同,但不能顯示非格式字符串, 也就是不能顯示提示字符串。地址表列中給出各變量的地址。地址是由地址運算符“&”後跟變量名組成的。例如,&a,&b分別表示變量a和變量b 的地址。這個地址就是編譯系統在內存中給a,b變量分配的地址。在C語言中,使用了地址這個概念,這是與其它語言不同的。 應該把變量的值和變量的地址這兩個不同的概念區別開來。變量的地址是C編譯系統分配的,用戶不必關心具體的地址是多少。 變量的地址和變量值的關係如下:scanf(“%d”,&a); 輸入567。 a為變量名,567是變量的值,&a是變量a的地址。在賦值表達式中給變量賦值,如: a=567 在賦值號左邊是變量名,不能寫地址,而scanf函數在本質上也是給變量賦值,但要求寫變量的地址,如&a。 這兩者在形式上是不同的。&是一個取地址運算符,&a是一個表達式,其功能是求變量的地址。
void main{
int a,b,c;
printf("input a,b,c\n");
scanf("%d%d%d",&a,&b,&c);
printf("a=%d,b=%d,c=%d",a,b,c);
}
注意&的用法!
在本例中,由於scanf函數本身不能顯示提示串,故先用printf語句在屏幕上輸出提示,請用戶輸入a、b、c的值。執行scanf語句,則進入用戶屏幕等待用戶輸入。用戶輸入7 8 9後按下回車鍵,此時,系統又將返回編輯屏幕。在scanf語句的格式串中由於沒有非格式字符在“%d%d%d”之間作輸入時的間隔,因此在輸入時要用一個以上的空格或回車鍵作為每兩個輸入數之間的間隔。
如: 7 8 9
或
7
8
9
(二)格式字符串
格式字符串的一般形式為: %類型
類型:表示輸入數據的類型,其格式符和意義下表所示。
格式 字符意義
d 輸入十進制整數
o 輸入八進制整數
x 輸入十六進制整數
u 輸入無符號十進制整數
f或e 輸入實型數(用小數形式或指數形式)
c 輸入單個字符
s 輸入字符串
使用scanf函數還必須注意以下幾點:
a. scanf函數中沒有精度控制,如: scanf("%
b. scanf中要求給出變量地址,如給出變量名則會出錯。如 scanf("%d",a);是非法的,應改為scnaf("%d",&a);才是合法的。
c. 在輸入多個數值數據時,若格式控制串中沒有非格式字符作輸入數據之間的間隔則可用空格,TAB或回車作間隔。C編譯在碰到空格,TAB,回車或非法數據(如對“%d”輸入“
d. 在輸入字符數據時,若格式控制串中無非格式字符,則認為所有輸入的字符均為有效字符。例如:
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);則輸入時各數據之間可加空格。
void main{
char a,b;
printf("input character a,b\n");
scanf("%c%c",&a,&b);
printf("%c%c\n",a,b);
}
由於scanf函數"%c%c"中沒有空格,輸入M N,結果輸出只有M。
而輸入改為MN時則可輸出MN兩字符,見下面的輸入運行情況:
input character a,b
MN
scanf("%c %c",&a,&b);
printf("\n%c%c\n",a,b);
}
本例表示scanf格式控制串"%c %c"之間有空格時,輸入的數據之間可以有空格間隔。
e. 如果格式控制串中有非格式字符則輸入時也要輸入該非格式字符。
例如:
scanf("%d,%d,%d",&a,&b,&c); 其中用非格式符“ , ”作間隔符,故輸入時應為: 5,6,7
又如: scanf("a=%d,b=%d,c=%d",&a,&b,&c);
則輸入應為
a=5,b=6,c=7
f. 如輸入的數據與輸出的類型不一致時,雖然編譯能夠通過,但結果將不正確。
void main{
int a;
printf("input a number\n");
scanf("%d",&a);
printf("%f",a);
}
由於輸入數據類型為整型, 而輸出語句的格式串中說明為浮點型,因此輸出結果和輸入數據不符。
(三)鍵盤輸入函數
getchar函數getchar函數的功能是從鍵盤上輸入一個字符。其一般形式為: getchar; 通常把輸入的字符賦予一個字符變量,構成賦值語句,如:
char c;
c=getchar;
printf("input a character\n");
c=getchar;
putchar(c);
}
使用getchar函數還應注意幾個問題:
1.getchar函數只能接受單個字符,輸入數字也按字符處理。輸入多於一個字符時,只接收第一個字符。
2.使用本函數前必須包含文件“cstdio”。
練習題
練習1、在秋季足球賽中,高二某班共參加了5場比賽,請輸入5場球賽的分數,求出該班總分並輸出。要求:競賽成績為整數類型,用c++語言編寫程序,文件名:姓名01.cpp,如:李明01.cpp。
例:輸入:分數:1 2 3 4 5 , 輸出:總分=15
練習2、輸入圓的半徑,求圓的面積和周長並輸出。
pi=3.1415
面積S=pi*r*r
周長C=2*pi*r
提示:請提交源文件(.cpp文件),文件名:姓名+題號,如:甄鳴3.2.cpp。
圓的半徑、面積和周長應該是實數類型。
練習3、要將“China”譯成密碼,密碼規律是:用原來的字母后面第4個字母代替原來的字母。例如,字母“A”後面第4個字母是“E”,用“E”代替“A”。因此,“China”應譯為“Glmre”。請編寫一個程序,任意輸入5個字符,輸出加密後的5個字符。
要求:用c語言編寫程序,文件名:姓名3.3.cpp,如:李明3.3.cpp。
例:輸入 china 輸出 glmre
練習4、輸入一個三位正整數,將其反向後輸出。
例:輸入:123,輸出:321。
提示:按整數處理。請提交源文件(.cpp文件),文件名:姓名+題號,如:甄鳴3.4.cpp。
閱讀更多 老猿科普 的文章