版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、第七章 數(shù) 組 7.1 數(shù)據(jù)結構與數(shù)組的概念 影響程序設計的因素除算法外還有數(shù)據(jù)結構。 ■數(shù)據(jù)結構概念 編寫一個程序除了重視算法的設計外,還需重視數(shù)據(jù)類型的選擇,即選擇合適的數(shù)據(jù)類型來存放要處理的數(shù)據(jù)。在程序設計中,數(shù)據(jù)類型就稱為數(shù)據(jù)結構,選擇合適的數(shù)據(jù)類型實際上就是進行數(shù)據(jù)結構的設計。,在程序設計中有格言: 數(shù)據(jù)結構+算法=程序 說明數(shù)據(jù)結構與算法同等重要,算法依賴于數(shù)據(jù)結構,對于同一個問題的求
2、解,可以采用不同的數(shù)據(jù)結構和不同的算法,對不同的數(shù)據(jù)結構有不同的算法,其復雜程度也會不同,選擇合適的數(shù)據(jù)結構,可以降低算法的復雜程度。因此,在程序設計中應重視數(shù)據(jù)結構的設計。,例:求任意100個數(shù)中的最大值。 main() { int i,a,max; max=-32768 for(i=1;imax) max=a; } printf(“\n max=%d”,max); },用一個簡單變
3、量作為數(shù)據(jù)結構,合理,算法簡單,對于三個數(shù)的排序:main(){ int a,b,c,t; scanf(“%d,%d,%d”,&a,&b,&c); if(a<b) {t=a; a=b; b=t;} if(a<c) {t=a; a=c; c=t;} if(b<c) {t=b; b=c; c=t; } printf(“\n %d,%d,%d”,a,b,
4、c);}對于很多個數(shù)的排序用變量會很復雜而用數(shù)組會使算法很簡單。,,仍可用變量作為數(shù)據(jù)結構,■數(shù)組的概念 一組具有同樣類型的數(shù)據(jù)的集合 統(tǒng)一用一個名字代表---數(shù)組名(代表一組數(shù)) 將一組數(shù)用一個名字代表,便于管理。,,int a[10],數(shù)組名,,數(shù)組大小,,數(shù)組中的各成員稱數(shù)組元素,由數(shù)組名加下標唯一地確定。,只有一個下標的數(shù)組稱為一維數(shù)組;可有二維數(shù)組、三維數(shù)組、…、七維數(shù)組。,7.2 一維數(shù)組的定義
5、和引用 ■定義 一般形式: 類型符 數(shù)組名[常量表達式]; int a[10]; float b[10]; 類型符 數(shù)組名 長度 作用:分配一組連續(xù)的內存單元,,,,說明: ●數(shù)組必須先定義后使用。 ●數(shù)組名的命名規(guī)則與變量相同。 ●常量表達式表示元素的個數(shù)(長度),下標 從0開始。 ●常量表達式不能包含變量,即不允許作動態(tài)定義。,■引用 逐個引用其
6、元素,不能進行整體引用。 引用的一般形式: 數(shù)組名[下標] 如:a[0]=50; a[1]=100; a[2]=a[0]+a[1]; 與 a2=a0+a1有根本性的區(qū)別:下標可變。,例:從鍵盤輸入10個數(shù)。用變量:(不方便)scanf(“%d%d%d%d%d%d%d%d%d%d”, &a0,&a1,&a2,&a3,&a4,&a5
7、,&a6,&a7,&a8,&a9);用數(shù)組: (靈活方便) for(i=0;i<10;i++) scanf(“%d”,&a[i]); 用循環(huán)控制輸入個數(shù)和下標的變化。 注意下標的變化范圍。,■初始化 eg7-0 在定義數(shù)組的同時給數(shù)組賦初值。 int a[10]={0,1,2,3,4,5,6,7,8,9}; int a[10]={0,1,2,3,4};
8、 int a[]={0,1,2,3,4};,■應用舉例(1)對100個學生的分數(shù)統(tǒng)計最高分、最低分和平均分。 兩種方法: 用變量作為存放初始數(shù)據(jù)的數(shù)據(jù)結構 用數(shù)組作為存放初始數(shù)據(jù)的數(shù)據(jù)結構,main() { int i,a,max,min; float aver=0; max=0; min=100; for(i=0;imax) max=a;
9、 if(a<min) min=a; aver+=a; } aver/=100; printf(“\n %d,%d,%f”,max,min,aver); },用變量eg7-1,#define N 100 main() { int i,a[N],max,min; float aver=0; for(i=0;imax) max=a[i];
10、 if(a[i]<min) min=a[i]; aver+=a[i]; } aver/=N; printf(“\n %d,%d,%f”,max,min,aver); },用數(shù)組eg7-2,找最大最小的位置?eg7-3,max=0; min=0;,if(a[i]>a[max]) max=i;if(a[i]<a[min]) min=i;,(2)統(tǒng)計高于
11、平均分的人數(shù)。,main(){ int i,a,n; float aver=0; for(i=0;i<100;i++) { scanf(“%d”,&a); aver+=a; } aver/=100;,n=0; for(i=0;iaver)n++; } printf(“\n %d”,n);},用變量,數(shù)據(jù)結構不合理,#define N 100main(){ int
12、 i,a[N],n; float aver=0; for(i=0;iaver)n++; printf(“\n %d”,n);},用數(shù)組eg7-4,(3)對100個學生的分數(shù)統(tǒng)計出每分一檔人數(shù)。 0 ? 1 ? 2 ? 3 ? 4
13、 ? ┇ ┇ 99 ? 100 ?,#define N 100main(){ int i,a; for(i=1;i<=N;i++) { scanf(“%d”,&a); } 輸出 },int i,a,n[N+1];for(i=0;i<N+1;i++) n[i]=0;,n[
14、a]++;,完整程序: eg7-5#define N 100main(){ int i,a,n[N+1]; for(i=0;i=0;i--) printf(“\n %3d:%3d”,i,n[i]);},體會數(shù)組作為存放結果的數(shù)據(jù)結構時的優(yōu)越性。,按10分一檔統(tǒng)計? eg7-6#define N 100main(){ int i,a,n[N+1]; for(i=0;i<N+1;i++)
15、n[i]=0; for(i=1;i<=N;i++) { scanf(“%d”,&a); n[a]++; }},int i,a,n[11];for(i=0;i<11;i++)n[i]=0;,n[a/10]++;,#define N 10,(4)對10個學生的分數(shù)按從小到大的順序排序后輸出。 兩種典型的排序算法:選擇法和起泡法。選擇法基本思想:
16、首先選擇最小的數(shù)放在0位置,再在剩下的數(shù)中選擇最小的數(shù)放在下一位置,┈┈,依次類推,共進行9次選擇。 5 8 7 4 3 9 0 1 2 6,每次選擇都要與其后的所有數(shù)進行比較換位。 5 8 7 4 3 9 0 1 2 6,,,,,,,,,,,,,,i,j,for(i=0;ia[j]) { t=a[i];
17、 a[i]=a[j]; a[j]=t; },eg7-7#define N 10main(){ int a[N],i,j,t; for(i=0;ia[j]) { t=a[i]; a[i]=a[j]; a[j]=t; } for(j=0;j<N;j++) printf(“%3d”,a[j]); },5 8 7 4 3 9 0 1 2 6,5
18、8 7 4 3 9 0 1 2 6,,,,,,,,,,,,,,i,j,小改進:先找最小值所在的位置,最后再換位:,for(i=0;i<N-1;i++) { k=i; for(j=i+1;j<N;j++) if(a[j]<a[k])k=j; t=a[i]; a[i]=a[k]; a[k]=t;
19、},#define N 10main(){ int a[N],i,j,t,k; for(i=0;i<N;i++)scanf(“%d”,&a[i]); for(i=0;i<N-1;i++) { k=i; for(j=i+1;j<N;j++) if(a[j]<a[k])k=j; t=a[i]; a[i]=a[k]; a[k]=t; } for
20、(j=0;j<N;j++) printf(“%3d”,a[j]); }eg7-8,5 8 7 4 3 9 0 1 2 6,起泡法基本思想: 首先將所有數(shù)中的最大值“冒泡”到最后位置,再將剩下的數(shù)中的最大值“冒泡”到上一位置,┈┈,依次類推,共進行9次“冒泡”。 每次“冒泡”都是一種翻滾過程,即相鄰兩個數(shù)進行比較換位。 5 8 7 4 3 9 0 1 2 6,,,,,,,,,,
21、,,,,#define N 10main(){ int a[N],i,j,t; for(i=0;ia[j+1]) {t= a[j]; a[j]= a[j+1]; a[j+1]=t;} for(j=0;j<N;j++) printf(“%3d”,a[j]); } 要特別注意兩個循環(huán)的范圍。eg7-9,5 8 7 4 3 9 0 1 2 6,(5) 循環(huán)移位 對一數(shù)列中
22、的每個數(shù)向后移3個位置,最后3個數(shù)移到最前面。 5 8 7 4 3 9 0 1 2 6 1 2 6 5 8 7 4 3 9 0,,用循環(huán)移位實現(xiàn): 5 8 7 4 3 9 0 1 2 6main(){ int i,j,k,a[10
23、]; for(i=0;i<10;i++)scanf(“%d”,&a[i]); for(i=0;i<10;i++)printf(“%3d”,a[i]); } eg7-10,for(i=1;i<10;i++)a[i]=a[i-1];,for(i=9;i>0;i--)a[i]=a[i-1];,k=a[9];,a[0]=k;,for(j=1;j<=3;j++){
24、k=a[9];,},用循環(huán)移位實現(xiàn): 5 8 7 4 3 9 0 1 2 6#define N 10#define M 3void main(){int i,j,k,a[N];for(i=0;i0;i--) a[i]=a[i-1];a[0]=k;}for(i=0;i<N;i++) printf("%3d,",a[i]);}eg7-10,(6)狐貍找兔子問題
25、 圍繞著山頂有10個洞,一只兔子和一只狐貍分別住在洞里,狐貍總想吃掉兔子;一天,兔子對狐貍說:你想吃掉我有一個條件,先把洞順序編號,你從最后一個洞出發(fā),第一次先到第一個洞找我,第二次隔一個洞找,第三次隔兩個洞找,┈,依次類推,尋找次數(shù)不限,我躲在一個洞里不動,只要找到我你就可以飽餐一頓。狐貍一想只有10個洞,尋找次數(shù)又不限,那有找不到的呢?馬上答應了條件,結果狐貍跑斷了腿也沒找到,請問兔子躲在哪個洞里?,,0,1,2,3,5,6,
26、7,8,9,4,,算法思想: 開辟數(shù)組,每個元素代表一個洞,并賦初值0,表示各個洞都還未找,然后按規(guī)律找,每找一個洞,對應的數(shù)組元素就賦值1,表示已找過,┈┈,最后根據(jù)數(shù)組元素值1與0來識別各洞是否已找過。,main(){ int i, k=9; int a[10]={0}; for(i=0;i<=10000;i++) { k=(k+i)%10; a[k]=1; } f
27、or(i=0;i<10;i++) if(a[i]==0) printf(“%3d”,i+1); }eg7-11,7.3 二維數(shù)組的定義和引用 ■定義 一般形式:類型符 數(shù)組名[常量表達式] [常量表達式]; int a[3][4]; float b[5][10]; 行 列,,,二維數(shù)組的邏輯結構就如同一張表格: a[
28、0][0] a[0][1] a[0][2] a[0][3] a[1][0] a[1][1] a[1][2] a[1][3] a[2][0] a[2][1] a[2][2] a[2][3] 存放形式:按行存放。,,,,,,,,,,a[0],a[1],a[2],二維數(shù)組可以看作是一個特殊的一維數(shù)
29、組,它的元素又是一個一維數(shù)組。C語言這樣的處理方法在很多情況下顯得很方便。 與一維數(shù)組相比,二維數(shù)組的定義多一個長度,其元素多一個下標。 在應用中,如果要處理的數(shù)據(jù)如同一數(shù)列,則可定義一維數(shù)組來存放;而如果要處理的數(shù)據(jù)如同一張表格,則應定義二維數(shù)組來存放。,■引用 引用形式:數(shù)組名[下標][下標] 如:a[0][3]=a[1][2]+a[2][3]; 其元素有兩個下標。 例:從鍵盤輸入12個數(shù)到二維數(shù)
30、組中。 int a[3][4],i,j; for(i=0;i<3;i++) for(j=0;j<4;j++) scanf(“%d”,&a[i][j]);需要用兩重循環(huán)來控制兩個下標的變化。,如果鍵盤輸入的數(shù)據(jù)是:1 2 3 4 5 6 7 8 9 10 11 12, 則在數(shù)組中如何存放?兩個循環(huán)換位呢?兩個下標換位呢? int a[3][4],i,j; for(i
31、=0;i<3;i++) for(j=0;j<4;j++) scanf(“%d”,&a[i][j]); eg7-12-1、 eg7-12-2、 eg7-12-3,for(j=0;j<4;j++) for(i=0;i<3;i++) scanf(“%d”,&a[i][j]);,int a[4][3],i,j; for(i=0;i<3;i++)
32、 for(j=0;j<4;j++) scanf(“%d”,&a[j][i]);,例:輸入一個表格的數(shù)據(jù)到二維數(shù)組中,并找最 大值所在的位置eg7-13main(){ int a[3][4],i,j,i1,j1; for(i=0;ia[i1][j1]){i1=i; j1=j;} printf(“\n %d,%d”,i1,j1); },■初始化 對二維數(shù)組賦初值的幾種方法: int
33、 a[3][4]= {{1,2,3,4},{5,6,7,8},{9,10,11,12}}; int a[3][4]={1,2,3,4,5,6,7,8,9,10,11,12}; int a[3][4]={{1},{5},{9}}; int a[3][4]={{1},{0,6},{0,0,11}}; int a[3][4]={{1},{5,6}}; int a[3][4]={{1},{0},{9}}; int a[]
34、[4]={1,2,3,4,5,6,7,8,9,10,11,12}; int a[][4]={{0,0,3},{0},{9,10}};,■ 舉例(1)矩陣的基本操作 二維數(shù)組的邏輯結構就如同一個矩陣,因此,矩陣操作都可用二維數(shù)組實現(xiàn)。,a11 a12 a13 … a1na21 a22 a23 … a2na31 a32 a33 … a3n
35、 … … … …am1 am2 am3 … amn,,,,,,,A=,,假定M=3,N=4,求和:#define M 3#define N 4main(){ int a[M][N],i,j,s=0; ┈┈┈ for(i=0;i<M;i++) for(j=0;j<N;j++) s+=a[i][j]; ┈┈┈ } 上三角?下
36、三角?主對角線?eg7-14-1、 eg7-14-2、 eg7-14-3、 eg7-14-4、 eg7-14-5,for(i=0;i<M;i++) for(j=i;j<N;j++) s+=a[i][j];,for(i=0;i<M;i++) for(j=0;j<=i;j++) s+=a[i][j];,for(i=0;i<M;i++) for(j=i;j<=i;j++) s+=a[i][j];,f
37、or(i=0;i<M;i++) s+=a[i][i];,1 2 3 45 6 7 89 10 11 12,非方陣轉置:aij→bji#define M 3#define N 4main(){ int a[M][N],b[N][M],i,j; ┈┈┈ for(i=0;i<M;i++) for(j=0;j<N;j++) b[j][i]=a
38、[i][j]; ┈┈┈ }eg7-15,1 2 3 45 6 7 89 10 11 12,1 5 9 2 6 103 7 114 8 12,,方陣轉置:aij∽aji#define M 3main(){ int a[M][M],i,j,t; ┈┈┈ for(i=0; i<M; i++) for(j=0; j<
39、M; j++) {t=a[i][j]; a[i][j]=a[j][i]; a[j][i]=t;} ┈┈┈ }eg7-16-1、 eg7-16-2,1 2 34 5 67 8 9,for(j=i+1; j<M; j++),1 2 34 5 67 8 9,1 4 72 5 83 6 9,將矩陣中和值為最大的那一行元素與首行對換。#defi
40、ne M 3#define N 4main(){ int a[M][N],i,j,t,s,smax=-32768,row; ┈┈┈ for(i=0;ismax) {smax=s; row=i;} } for(j=0;j<N;j++) {t=a[0][j];a[0][j]=a[row][j]; a[row][j]=t;} ┈┈┈} eg7-17,1 5 3 8
41、4 6 1 79 2 5 6,9 2 5 64 6 1 71 5 3 8,,7.4 字符數(shù)組 用于存放字符的數(shù)組稱字符數(shù)組。 字符數(shù)組的每一個元素存放一個字符。 字符數(shù)組的獨特之處: (1)字符數(shù)組可以看作字符串變量。 (2)對字符數(shù)組可以進行某些整體操作。 (3)有專用的字符串處理函數(shù)。,1、將字符數(shù)組
42、作為字符串變量 char c[10]; 給c分配10個字節(jié)的內存單元。 把c看作數(shù)組時,按數(shù)組元素的形式訪問: c[0]=’a’; c[1]=’b’; c[2]=’c’; c[3]=’d’; a b c d char c[10]={‘a’,’b’,’c’,’d’} ; 也屬于字符賦初值的形式。,,,,,,,,,,,,,,如果把字符序列看作一個整體(字符串),則c就可
43、看作是存放這個字符串的串變量;但必須在字符序列后加上“字符串結束標志”后,才能成為完整的字符串。 如:c[4]=’\0’; 或 c[4]=0;a b c d \0 也可以按字符串形式初始化: char c[10]=”abcd”; a b c d \0 \0 \0 \0 \0 \0 char c[]=”abcd”; 分配5個字節(jié) a b c d \0,2、對字符數(shù)組的整體操作 對
44、字符數(shù)組的有些操作可以整體進行,如輸入輸出。 for(i=0;i<10;i++) printf(“%c”,c[i]); 對數(shù)組元素操作 printf(“%s”,c); 整體操作 注意以上兩種操作有區(qū)別。 可將前者改為: for(i=0;c[i]!=’\0’;i++)printf(“%c”,c[i]);,對于輸入: for(i=0;i<1
45、0;i++) scanf(“%c”,&c[i]); 對數(shù)組元素操作 scanf(“%s”,c); 整體操作 對字符數(shù)組輸入輸出可以整體進行,但不允許整體賦值: char c[10]=”abcd”,x[10]; x=c; 不允許eg7-string.c,對于二維字符數(shù)組,可以看作是一維的字符串數(shù)組。 例:從鍵盤輸入10個人的名字到
46、計算機:#define M 20#define N 10 main() { int i; char name[N][M]; 10個元素的一維字符串數(shù)組 for(i=0;i<N;i++) scanf(“%s”,name[i]); … } 只給一個下標eg7-18,,3、字符串處理函數(shù) c語言的函數(shù)庫中提供了一系列專用于字符串處理的函數(shù),需要
47、時可直接調用。 使用字符串處理函數(shù)需要包含頭文件string.h (1)puts(字符串) 用于輸出字符串。 其中字符串可以是字符串常量,也可以是字符數(shù)組。 例:eg7-puts.c char str[]=”China”; puts(str); puts(”China”); 兩個輸出等效,(2)gets(字符數(shù)組) 用于從鍵盤輸入一個字符串到字符數(shù)組中。 函數(shù)返回字符數(shù)組的起始地址。
48、 例:eg7-gets.c char str[10]; gets(str); 執(zhí)行該函數(shù)調用時,計算機等待輸入字符串,(3)strcat(字符數(shù)組,字符串) 用于將字符串連接到字符數(shù)組的后面。 其中字符串可以是字符串常量,也可以是字符數(shù)組。 例:eg7-strcat.c char a[10]=”abcd”, b[10]=”xyz”; strcat(a,b); 與str
49、cat(a,”xyz”)等效 puts(a); 輸出結果是:abcdxyz,(4) strcpy(字符數(shù)組,字符串) 用于將字符串拷貝到字符數(shù)組中。 其中字符串可以是字符串常量,也可以是字符數(shù)組。 例:eg7-strcpy.c char a[10], b[10]=”abcdef”; strcpy(a,b); 與strcpy(a,”abcdef”)等效 不能用a
50、=b 賦值 puts(a); 輸出結果是:abcdef,(5) strcmp(字符串1,字符串2) 用于比較兩個字符串的大小。 比較結果通過函數(shù)的返回值體現(xiàn): 字符串1=字符串2時:返回0。 字符串1>字符串2時:返回一正整數(shù)。 字符串1<字符串2時:返回一負整數(shù)。,兩個字符串之間誰大誰小取決于最先有差異的兩個字符的ASCII代碼的大小。 如: strcmp(“abcde”,”abcde
51、”); 返回0 strcmp(“abcdefgh”,”abcxyz”);返回負整數(shù) strcmp(“a”,”ABCD”); 返回正整數(shù),例:從鍵盤輸入兩個字符串,輸出其中大的一個。#include “string.h” main(){ char a[10],b[10]; gets(a); gets(b); if(strcmp(a,b)>0) puts(a); 不能用a>
52、b else puts(b); }eg7-strcmp.c,(6) strlen(字符數(shù)組) 測試字符串的實際長度(從返回值得到)。 (7) strlwr(字符串) 將字符串中的大寫字母全改為小寫字母。 (8) strupr(字符串) 將字符串中的小寫字母全改為大寫字母。 注意:在使用字符串處理函數(shù)時,別忘了將頭文件string.h包含進去。eg7-strfuc.c,4、字符串
53、操作舉例(1)從鍵盤輸入一字符串到數(shù)組a中,再拷貝到數(shù)組b中(不用庫函數(shù))。 eg7-strcpy.c main() { char a[50],b[50]; int i; scanf(“%s”,a); for(i=0; a[i]; i++) b[i]=a[i]; b[i]=0; printf(“%s”,b); },(2)從鍵盤輸入兩個字符串到數(shù)組a和b中,在將b中的內容連接到a中
54、(不用庫函數(shù))。main(){ char a[50],b[50]; int i,j; scanf(“%s%s”,a,b); for(i=0; a[i]; i++); for(j=0; b[j]; j++) a[i++]=b[j]; a[i]=0; printf(“%s”,a);} eg7-strcat.c,(3)從鍵盤輸入一字符串,并將其中的大寫字母改成小寫字母后輸出(不用庫
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- [學習]樊媛媛c語言程序設計
- [學習]樊媛媛c語言程序設計08-函數(shù)
- [學習]樊媛媛c語言程序設計10-指針
- [學習]樊媛媛c語言程序設計06-循環(huán)控制
- [學習]樊媛媛c語言程序設計11-結構體
- [學習]樊媛媛c語言程序設計09-編譯預處理
- c語言程序設計第七章數(shù)組
- 高級語言程序設計(c++) 數(shù)組 習題及答案
- 《c語言程序設計》
- c語言程序設計
- c語言程序設計
- c語言程序設計
- c語言程序設計
- 程序設計基礎c實驗報告數(shù)組
- c語言程序設計學習資料及答案
- c語言程序設計(譚浩強)
- c語言程序設計教程
- c語言程序設計3
- c語言程序設計論文
- c語言程序設計論文
評論
0/150
提交評論