資源簡介 (共34張PPT)《C程序設計》第三章 順序程序設計——最簡單的C程序設計從程序流程的角度來看,程序可以分為三種基本結構,即順序結構、分支結構、循環結構。這三種基本結構可以組成所有的各種復雜程序。C語言提供了多種語句來實現這些程序結構。本章介紹這些基本語句及其在順序結構中的應用,使讀者對C程序有一個初步的認識,為后面各章的學習打下基礎。以下對一些基本的C語句進行介紹,知道的可跳過!!介紹 ~C程序的執行部分是由語句組成的。程序的功能也是由執行語句實現的。C語句可分為以下五類:1) 表達式語句2) 函數調用語句3) 控制語句4) 復合語句5) 空語句表達式語句:表達式語句由表達式加上分號“;”組成。其一般形式為: 表達式;執行表達式語句就是計算表達式的值。例如:x=y+z; 賦值語句;y+z; 加法運算語句,但計算結果不能保留,無實際意義;i++; 自增1語句,i值增1。2. 函數調用語句:由函數名、實際參數加上分號“;”組成。其一般形式為:函數名(實際參數表);執行函數語句就是調用函數體并把實際參數賦予函數定義中的形式參數,然后執行被調函數體中的語句,求取函數值 (在后面函數中再詳細介紹) 。例如:printf("C Program");調用庫函數,輸出字符串。3. 控制語句:控制語句用于控制程序的流程,以實現程序的各種結構方式。它們由特定的語句定義符組成。C語言有九種控制語句。可分成以下三類:1) 條件判斷語句:if語句、switch語句;2) 循環執行語句:do while語句、while語句、for語句;3) 轉向語句:break語句、goto語句、continue語句、return語句。4. 復合語句:把多個語句用括號{}括起來組成的一個語句稱復合語句。在程序中應把復合語句看成是單條語句,而不是多條語句。例如:{x=y+z;a=b+c;printf(“%d%d”,x,a);}是一條復合語句。復合語句內的各條語句都必須以分號“;”結尾,在括號“}”外不能加分號。5. 空語句:只有分號“;”組成的語句稱為空語句。空語句是什么也不執行的語句。在程序中空語句可用來作空循環體。例如while(getchar()!='\n'){;}本語句的功能是,只要從鍵盤輸入的字符不是回車則重新輸入。這里的循環體為空語句。C基本語句介紹賦值語句是由賦值表達式再加上分號構成的表達式語句。其一般形式為: 變量 = 表達式;賦值語句的功能和特點都與賦值表達式相同。它是程序中使用最多的語句之一。在賦值語句的使用中需要注意以下幾點:1. 由于在賦值符“=”右邊的表達式也可以又是一個賦值表達式,因此,下述形式:變量=(變量=表達式);是成立的,從而形成嵌套的情形。其展開之后的一般形式為:變量=變量=…=表達式;例如:a=b=c=d=e=5;按照賦值運算符的右接合性,因此實際上等效于:e=5;d=e;c=d;b=c;a=b;賦值語句2. 注意在變量說明中給變量賦初值和賦值語句的區別。給變量賦初值是變量說明的一部分,賦初值后的變量與其后的其它同類變量之間仍必須用逗號間隔,而賦值語句則必須用分號結尾。例如:int a=5,b,c;3. 在變量說明中,不允許連續給多個變量賦初值。如下述說明是錯誤的:int a=b=c=5必須寫為int a=5,b=5,c=5;而賦值語句允許連續賦值。賦值語句4. 注意賦值表達式和賦值語句的區別。賦值表達式是一種表達式,它可以出現在任何允許表達式出現的地方,而賦值語句則不能。下述語句是合法的:if((x=y+5)>0) z=x;語句的功能是,若表達式x=y+5大于0則z=x。下述語句是非法的:if((x=y+5;)>0) z=x;因為x=y+5;是語句,不能出現在表達式中。賦值語句1) 所謂輸入輸出是以計算機為主體而言的。2) 本章介紹的是向標準輸出設備顯示器輸出數據的語句。3) 在C語言中,所有的數據輸入/輸出都是由庫函數完成的。因此都是函數語句。4) 在使用C語言庫函數時,要用預編譯命令#include將有關“頭文件”包括到源文件中。使用標準輸入輸出庫函數時要用到 “stdio.h”文件,因此源文件開頭應有以下預編譯命令:#include< stdio.h >或#include ”stdio.h”stdio是standard input &outupt的意思。5) 考慮到printf和scanf函數使用頻繁,系統允許在使用這兩個函數時可不加#include< stdio.h >或#include ”stdio.h”數據輸入輸出的概念及在C語言中的實現putchar 函數(字符輸出函數)putchar 函數是字符輸出函數,其功能是在顯示器上輸出單個字符。其一般形式為:putchar(字符變量)例如:putchar('A'); (輸出大寫字母A)putchar(x); (輸出字符變量x的值)putchar(‘\101’); (也是輸出字符A)putchar('\n'); (換行)對控制字符則執行控制功能,不在屏幕上顯示。使用本函數前必須要用文件包含命令:#include或#include “stdio.h”字符數據的輸入輸出【例4.1】輸出單個字符。#includevoid 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);}字符數據的輸入輸出getchar函數(鍵盤輸入函數)getchar函數的功能是從鍵盤上輸入一個字符。其一般形式為:getchar();通常把輸入的字符賦予一個字符變量,構成賦值語句,如:char c;c = getchar();字符數據的輸入輸出【例4.2】輸入單個字符。#includevoid main(){char c;printf("input a character\n");c = getchar();putchar(c);}字符數據的輸入輸出printf函數(格式輸出函數)printf函數稱為格式輸出函數,其關鍵字最末一個字母f即為“格式”(format)之意。其功能是按用戶指定的格式,把指定的數據顯示到顯示器屏幕上。在前面的例題中我們已多次使用過這個函數。1. printf函數調用的一般形式printf函數是一個標準庫函數,它的函數原型在頭文件“stdio.h”中。但作為一個特例,不要求在使用 printf 函數之前必須包含stdio.h文件。printf函數調用的一般形式為:printf(“格式控制字符串”,輸出表列)格式輸入與輸出printf函數(格式輸出函數)其中格式控制字符串用于指定輸出格式。格式控制串可由格式字符串和非格式字符串兩種組成。格式字符串是以%開頭的字符串,在%后面跟有各種格式字符,以說明輸出數據的類型、形式、長度、小數位數等。如:“%d”表示按十進制整型輸出;“%ld”表示按十進制長整型輸出;“%c”表示按字符型輸出等。非格式字符串在輸出時原樣照印,在顯示中起提示作用。輸出表列中給出了各個輸出項,要求格式字符串和各輸出項在數量和類型上應該一一對應。格式輸入與輸出【例4.3】void main(){int a=88,b=89;printf("%d %d\n",a,b);printf("%d,%d\n",a,b);printf("%c,%c\n",a,b);printf("a=%d,b=%d",a,b);}本例中四次輸出了a,b的值,但由于格式控制串不同,輸出的結果也不相同。第四行的輸出語句格式控制串中,兩格式串%d 之間加了一個空格(非格式字符),所以輸出的a,b值之間有一個空格。第五行的printf語句格式控制串中加入的是非格式字符逗號,因此輸出的a,b值之間加了一個逗號。第六行的格式串要求按字符型輸出 a,b值。第七行中為了提示輸出結果又增加了非格式字符串。格式輸入與輸出格式字符串1) 類型:類型字符用以表示輸出數據的類型,其格式符和意義如下表所示:格式輸入與輸出2) 標志:標志字符為-、+、#、空格四種,其意義下表所示:3) 輸出最小寬度:用十進制整數來表示輸出的最少位數。若實際位數多于定義的寬度,則按實際位數輸出,若實際位數少于定義的寬度則補以空格或0。4) 精度:精度格式符以“.”開頭,后跟十進制整數。本項的意義是:如果輸出數字,則表示小數的位數;如果輸出的是字符,則表示輸出字符的個數;若實際位數大于所定義的精度數,則截去超過的部分。5) 長度:長度格式符為h,l兩種,h表示按短整型量輸出,l表示按長整型量輸出。格式輸入與輸出【例4.4】void main(){int a=15;float b=123.1234567;double c=12345678.1234567;char d='p';printf("a=%d,%5d,%o,%x\n",a,a,a,a);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,%8c\n",d,d);}格式輸入與輸出使用printf函數時還要注意一個問題,那就是輸出表列中的求值順序。不同的編譯系統不一定相同,可以從左到右,也可從右到左。Turbo C是按從右到左進行的。請看下面兩個例子:【例4.5】void main(){int i=8;printf("%d\n%d\n%d\n%d\n%d\n %d\n",++i,--i,i++,i--,-i++,-i--);}【例4.6】void main(){int i=8;printf("%d\n",++i);printf("%d\n",--i);printf("%d\n",i++);printf("%d\n",i--);printf("%d\n",-i++);printf("%d\n",-i--);}這兩個程序的區別是用一個printf語句和多個printf 語句輸出。但從結果可以看出是不同的 !!格式輸入與輸出scanf函數(格式輸入函數)scanf函數稱為格式輸入函數,即按用戶指定的格式從鍵盤上把數據輸入到指定的變量之中。1. scanf函數的一般形式scanf函數是一個標準庫函數,它的函數原型在頭文件“stdio.h”中,與printf函數相同,C語言也允許在使用scanf函數之前不必包含stdio.h文件。scanf函數的一般形式為:scanf(“格式控制字符串”,地址表列);其中,格式控制字符串的作用與printf函數相同,但不能顯示非格式字符串,也就是不能顯示提示字符串。地址表列中給出各變量的地址。地址是由地址運算符“&”后跟變量名組成的。格式輸入與輸出例如:&a, &b分別表示變量a和變量b 的地址。這個地址就是編譯系統在內存中給a,b變量分配的地址。在C語言中,使用了地址這個概念,這是與其它語言不同的。應該把變量的值和變量的地址這兩個不同的概念區別開來。變量的地址是C編譯系統分配的,用戶不必關心具體的地址是多少。變量的地址和變量值的關系如下:在賦值表達式中給變量賦值,如:a = 567則,a為變量名,567是變量的值,&a是變量a的地址。但在賦值號左邊是變量名,不能寫地址,而scanf函數在本質上也是給變量賦值,但要求寫變量的地址,如&a。 這兩者在形式上是不同的。&是一個取地址運算符,&a是一個表達式,其功能是求變量的地址。格式輸入與輸出【例4.7】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);}格式輸入與輸出2. 格式字符串格式字符串的一般形式為:%[*][輸入數據寬度][長度]類型其中有方括號[]的項為任選項。各項的意義如下:1) 類型:表示輸入數據的類型,其格式符和意義如下表所示。格式輸入與輸出2) “*”符:用以表示該輸入項,讀入后不賦予相應的變量,即跳過該輸入值。如: scanf("%d %*d %d", &a, &b);當輸入為:1 2 3時,把1賦予a,2被跳過,3賦予b。3) 寬度:用十進制整數指定輸入的寬度(即字符數)。如: scanf("%5d", &a);輸入:12345678只把12345賦予變量a,其余部分被截去。如:scanf("%4d%4d", &a, &b);輸入:12345678將把1234賦予a,而把5678賦予b。格式輸入與輸出4) 長度:長度格式符為l和h,l表示輸入長整型數據(如%ld) 和雙精度浮點數(如%lf)。h表示輸入短整型數據。使用scanf函數還必須注意以下幾點:1) scanf函數中沒有精度控制,如:scanf("%5.2f",&a);是非法的。不能企圖用此語句輸入小數為2位的實數。2) scanf中要求給出變量地址,如給出變量名則會出錯。如 scanf("%d",a);是非法的,應改為scnaf("%d",&a);才是合法的。3) 在輸入多個數值數據時,若格式控制串中沒有非格式字符作輸入數據之間的間隔則可用空格,TAB或回車作間隔。C編譯在碰到空格,TAB,回車或非法數據(如對“%d”輸入“12A”時,A即為非法數據)時即認為該數據結束。格式輸入與輸出4) 在輸入字符數據時,若格式控制串中無非格式字符,則認為所有輸入的字符均為有效字符。例如: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);則輸入時各數據之間可加空格。格式輸入與輸出【例4.8】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兩字符。格式輸入與輸出【例4.9】void main(){char a,b;printf("input character a,b\n");scanf("%c %c",&a,&b);printf("\n%c%c\n",a,b);}本例表示scanf格式控制串"%c %c"之間有空格時,輸入的數據之間可以有空格間隔。格式輸入與輸出5) 如果格式控制串中有非格式字符則輸入時也要輸入該非格式字符。例如: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=76) 如輸入的數據與輸出的類型不一致時,雖然編譯能夠通過,但結果將不正確。格式輸入與輸出【例4.10】void main(){int a;printf("input a number\n");scanf("%d",&a);printf("%ld",a);}【例4.11】void main(){long a;printf("input a long integer\n");scanf("%ld",&a);printf("%ld",a);}比較一下:由于輸入數據類型為整型,而輸出語句的格式串中說明為長整型,因此輸出結果和輸入數據不符。輸入:1234567890格式輸入與輸出題目:輸入三個小寫字母,輸出其ASCII碼和對應的大寫字母。【例4.12】void main(){char a,b,c;printf("input character a,b,c\n");scanf("%c %c %c",&a,&b,&c);printf("%d,%d,%d\n%c,%c,%c\n",a,b,c,a-32,b-32,c-32);}格式輸入與輸出題目:輸出各種數據類型的字節長度。【例4.13】void main(){int a;long b;float f;double d;char c;printf("\nint:%d\nlong:%d\nfloat:%d\ndouble:%d\nchar:%d\n", sizeof(a), sizeof(b), sizeof(f), sizeof(d), sizeof(c));}格式輸入與輸出【例4.14】輸入三角形的三邊長,求三角形面積。已知三角形的三邊長a,b,c,則該三角形的面積公式為:其中s = (a+b+c)/2源程序如下:#includevoid main(){float a,b,c,s,area;scanf(“%f,%f,%f”,&a,&b,&c);s=1.0/2*(a+b+c);area=sqrt(s*(s-a)*(s-b)*(s-c));printf(“a=%7.2f,b=%7.2f,c=%7.2f,s=%7.2f\n”,a,b,c,s);printf(“area=%7.2f\n”,area);}順序結構程序設計舉例順序結構程序設計舉例 02源程序如下:#includevoid main(){double a, b, c, disc, x1, x2, p, q;scanf(“a=%f,b=%f,c=%f”, &a, &b, &c);disc = b*b - 4*a*c;p = -b / (2*a);q = sqrt(disc) / (2*a);x1 = p+q;x2 = p-q;printf(“\nx1=%5.2f\nx2=%5.2f\n”, x1, x2);}順序結構程序設計舉例 02 展開更多...... 收起↑ 資源預覽 縮略圖、資源來源于二一教育資源庫