C語言 數(shù)組 講解_第1頁
C語言 數(shù)組 講解_第2頁
C語言 數(shù)組 講解_第3頁
C語言 數(shù)組 講解_第4頁
C語言 數(shù)組 講解_第5頁
已閱讀5頁,還剩83頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

2023/7/111例求一個班100個學生的平均成績,然后統(tǒng)計高于平均分的人數(shù)。使用簡單變量和循環(huán)結構相結合的方法求平均成績:

aver=0;for(i=1;i<=100;i++){scanf(“%f”,&mark);aver=aver+mark;}aver=aver/100;2023/7/112

若要統(tǒng)計高于平均分的人數(shù),則無法實現(xiàn)。mark是一個簡單變量,存放的是最后一個學生的成績。

用已有知識解決方法:1.再重復輸入成績,帶來兩個問題:(1)輸入數(shù)據(jù)的工作量成倍增加;(2)若本次輸入的成績與上次不同,則統(tǒng)計的結果不正確。2.使用100個變量mark1,mark2,……,mark99,mark100。2023/7/113分析:1.此100個變量均為學生成績,表示同一類對象。2.數(shù)據(jù)類型相同。3.可以用序號區(qū)分不同的變量。

解決此問題的根本方法,引入數(shù)組,始終保持輸入的數(shù)據(jù),一次輸入,多次使用。除了int、float、char等基本數(shù)據(jù)類型外,C語言還提供了構造數(shù)據(jù)類型,來滿足不同應用的需要。構造數(shù)據(jù)類型是由基本數(shù)據(jù)類型按一定規(guī)則組成的,也稱作“導出類型”。構造數(shù)據(jù)類型包括數(shù)組、結構體、共用體。數(shù)組(array)能將具有相同類型的數(shù)據(jù)組合在一起,通常是用于處理批量數(shù)據(jù)。Anarrayisadatatypethatusessubscriptedvariablesandmakespossibletherepresentationofalargenumberofhomogeneousvalues.第4章數(shù)組和指針C語言數(shù)組講解數(shù)組的維數(shù)數(shù)組中能唯一確定數(shù)組元素的下標的個數(shù)稱為數(shù)組的維數(shù)一維數(shù)組:只用一個下標就能區(qū)分數(shù)組中的不同元素的二維數(shù)組:要用兩個下標才能區(qū)分數(shù)組中的不同元素1×6一維數(shù)組3×4二維數(shù)組2×3×4三維數(shù)組inta[6]; intb[3][4];intc[2][3][4];C語言數(shù)組講解4.1一維數(shù)組

4.1.1一維數(shù)組的定義與初始化

1.一維數(shù)組定義

類型定義符

數(shù)組名[整型常量表達式];【例如】

inta[6];/17a[0]0145a[1]a[2]a[3]a[4]a[5]23a數(shù)組名表示內(nèi)存首地址,是地址常量編譯時系統(tǒng)分配連續(xù)內(nèi)存內(nèi)存字節(jié)數(shù)=數(shù)組維數(shù)*sizeof(元素數(shù)據(jù)類型)數(shù)組a在內(nèi)存占24字節(jié)(6*4字節(jié))C語言數(shù)組講解Aone-dimensionalarraydeclarationisatypefollowedbyanidentifierwithabracketedconstantintegralexpression.Thevalueoftheexpression,whichmustbepositive,isthesizeofthearray.Itspecifiesthenumberofelementsinthearray.Thearraysubscriptscanrangefrom0tosize-1.Thelowerboundofthearraysubscriptsis0andtheupperboundissize-1.C語言數(shù)組講解4.1.1一維數(shù)組的定義與初始化【例如】floatscore[50];

charname[20];注意:

不能用變量定義數(shù)組的長度。

floatscore[n];×當定義數(shù)組語句中不同時給變量賦值時,方括號內(nèi)不得為空。

inta[];×數(shù)組一旦定義,數(shù)組的大小就不能再改變。常用的辦法是用符號常量來指定元素個數(shù)。

#definesize50

floatscore[size];/17C語言數(shù)組講解4.1.1一維數(shù)組的定義與初始化2.一維數(shù)組初始化類型定義符

數(shù)組名[常量]={值1,值2,…,值n};例如:inta[6]={1,2,3,4,5,6};inta[]={1,2,3,4,5,6};兩者等價于:a[0]=1;a[1]=2;a[2]=3;a[3]=4;a[4]=5;a[5]=6;例如:

inta[6]={1,2};等價于:a[0]=1;a[1]=2;a[2]=0;a[3]=0;a[4]=0;a[5]=6;intc[10]={0};//將0賦給c[0]~c[9]inta[]={1,2};//等價于:a[0]=1;a[1]=2;/17C語言數(shù)組講解4.1.2一維數(shù)組元素的引用與操作1.數(shù)組元素的引用

數(shù)組名[下標]注意:(1)數(shù)組元素的下標從0開始(2)引用數(shù)組元素時,只能單個引用,不能一次引用整個數(shù)組

inta[6];a={3,4,5,6,7};×a[6]={3,4,5,6,7};×(3)下標不要超出數(shù)組的范圍,否則導致錯誤的程序結果。/17C語言數(shù)組講解2.數(shù)組的賦值可以在定義數(shù)組時對數(shù)組中的全部變量或部分變量賦值(即數(shù)組的初始化)??梢栽谡Z句中為變量賦值。利用循環(huán)依次為每個數(shù)組元素賦值或輸入值。4.1.2一維數(shù)組元素的引用與操作main(){inti,a[5];

for(i=0;i<5;i++)a[i]=i;

//用循環(huán)結構直接對數(shù)組賦初值for(i=0;i<5;i++)

printf("%d,",a[i]);printf("\n");}

運行結果為:0,1,2,3,4,

C語言數(shù)組講解用交互的循環(huán)結構對數(shù)組賦初值main(){

inti,a[5];

for(i=0;i<5;i++)

printf("a[%d]=",i),scanf("%d",&a[i]);

for(i=0;i<5;i++) printf("%d,",a[i]);printf("\n");}C語言數(shù)組講解例:定義長度為10的整型類型一維數(shù)組并完成以下功能: ⑴從鍵盤輸入10個整數(shù),分別存放在10個數(shù)組元素中;⑵輸出數(shù)組中的各元素值;⑶按逆序輸出數(shù)組中的各元素值。main(){

inti,a[10];

for(i=0;i<10;i++) printf("第%d個數(shù)據(jù):",i+1), scanf("%d",&a[i]);

for(i=0;i<10;i++)printf("%4d",a[i]);printf("\n");

for(i=9;i>=0;i--)printf("%4d",a[i]);printf("\n");}應用舉例C語言數(shù)組講解下標越界:差一錯誤off-by-oneerror在C語言中,有N個元素的數(shù)組其元素下標的允許取值范圍為0到N-1,不存在下標為N的元素。例如這段代碼本意是要設置數(shù)組a中的10個元素均為0。但通常編譯器按內(nèi)存遞減方式分配內(nèi)存,使得內(nèi)存中a[9]之后的4個字節(jié)分配給i。本來計數(shù)器i的值為10,循環(huán)體內(nèi)將并不存在的a[10]設為0,實際是將i值設為0,就陷入死循環(huán)!main(){

inti,a[10];

for(i=1;i<=10;i++){ a[i]=0; printf("%d",a[i]); }}C語言數(shù)組講解4.1.3數(shù)組應用

1.比較法排序由鍵盤輸入10個數(shù),按由小到大排序輸出解題方法:將10個數(shù)存入數(shù)組a將a(0)與a(1)、a(2)……a(9)依次比較,哪個元素的值比a(0)小,就將它與a(0)的值交換,這樣就將最小的數(shù)送到了a(0)中。再將a(1)與a(2)、a(3)……a(9)依次比較,哪個元素的值比a(1)小,就將它與a(1)的值交換,這樣就將最小的數(shù)送到了a(1)中。重復以上步驟。對于n個數(shù),比較排序法的總運行次數(shù)為:

(n-1)+(n-2)+…+3+2+1=n*(n-1)/2.C語言數(shù)組講解/171.比較法排序1.比較法排序#include<stdlib.h>main(){

inti,j,a[10]; srand(time(0));

for(i=0;i<10;i++){ a[i]=rand()%101; printf("%4d",a[i]); } putch('\n');

for(i=0;i<9;i++){

for(j=i+1;j<10;j++)

if(a[i]>a[j]) a[i]^=a[j]^=a[i]^=a[j]; }

for(i=0;i<10;i++) printf("%4d",a[i]);}C語言數(shù)組講解2.冒泡法排序是一種交換類排序方法,它是通過相鄰數(shù)據(jù)元素的交換逐步將線性表變成有序。首先將a[0]與a[1]、a[1]與a[2]、a[2]與a[3]、……a[n-2]與a[n-1]相鄰兩個數(shù)進行比較,若為逆序(比如a[0]>a[1])則兩者交換,這樣就將將最大的數(shù)放在a[n-1]中;再將a[0]、a[1]、……a[n-2]這n-1個數(shù)進行同樣的相鄰兩數(shù)比較,若為逆序則兩者交換,這樣就將這n-1個數(shù)中最大的數(shù)被放在a[n-2]中;重復以上步驟,經(jīng)過n-1趟比較交換完成冒泡法排序。/17C語言數(shù)組講解/17用冒泡法排序將10個整數(shù)按從小到大的次序排列出來。2.冒泡法排序/17#include<stdio.h>#defineN10//數(shù)據(jù)的個數(shù)

main(){

inta[N]={5,12,29,47,9,18,13,50,38,2};

inti,j,k,t;

for(i=0;i<N-1;i++){

for(j=0;j<N-i;j++)

if(a[j]>a[j+1]){

t=a[j]; a[j]=a[j+1]; a[j+1]=t; } } printf("\n最后的排序結果:\n");

for(i=0;i<N;i++) printf("%5d",a[i]);}2.冒泡法排序數(shù)組應用II--插入向一個有序數(shù)組中插入一個數(shù)字,插入后不改變原有順序a[0]1a[1]2a[2]3a[3]4a[4]6a[5]7a[6]8a[7]9a[8]10a[9]0a[0]1a[1]2a[2]3a[3]4a[4]5a[5]6a[6]7a[7]8a[8]9a[9]10插入數(shù)字前插入數(shù)字后C語言數(shù)組講解/17方法1:找到插入點后再移位。從前向后循環(huán),從第1個元素開始依次將數(shù)組元素與要插入的數(shù)x比較,當x<a[i]時,將a[i]~a[8]依次向后移動,這時a[i]就可以存放x了。for(i=0;i<9;i++) {

//將要插入的數(shù)與每個元素比較,找插入的位置if(x<a[i]){

//依次將插入點后的元素向后移位for(j=8;j>=i;j--)a[j+1]=a[j];a[i]=x;

//插入數(shù)據(jù)后退出整個循環(huán)break;}}數(shù)組應用II--插入/17方法2:邊找插入點邊移位。從后向前循環(huán),直接從最后1個元素開始,將其與要插入的數(shù)x比較,如果x<a[i],說明x要插在a[i]的前面,那么a[i]元素就要向后移位;再將下標i--,做同樣的比較,直到找到插入點退出循環(huán),這時的a[i]>x,因此x要賦值給a[i+1]。//從最后1個元素開始,依次將要插入的數(shù)與每個元素比較for(i=8;i>=0;i--){

//如果要插入的數(shù)比元素值小,則該元素直接向后移位

if(x<a[i]) a[i+1]=a[i];

elsebreak;//表示找到插入點,退出循環(huán)}a[i+1]=x;

//插入數(shù)據(jù)數(shù)組應用II--插入數(shù)組應用III:不改變順序,刪除指定的數(shù)字main(){

inti,j,del=0,

inta[10]={1,2,3,4,5,6,7,8,9,10},x=5;for(i=0;i<10;i++) printf("%4d",a[i]);putch('\n');for(i=0;i<10-del;i++){//刪除后數(shù)組的容量減小一

if(x==a[i]){

for(j=i;j<10;j++) a[j]=a[j+1]; i--;//還原到刪除位置,以處理連續(xù)刪除

del++; }}for(i=0;i<10-del;i++) printf("%4d",a[i]);}刪除前:12345578910刪除后:123478910C語言數(shù)組講解二分法檢索(在序列x[]中檢索y的位置)前提:有序數(shù)列(以遞增序為例)原理:

等分區(qū)間;

若y小于中間數(shù),則取左半邊,否則取右半邊。再等分,再比較…例:對于區(qū)間[a,b]等分為若y==x[k]則位置為k若y<x[k]則取新區(qū)間[a,k-1](即b=k-1)若y>x[k]則取新區(qū)間[k+1,b](即a=k+1)數(shù)組應用IV–二分查找(檢索)C語言數(shù)組講解二分法查找遞增序列main(){

intx[10]={34,56,78,87,88,90,101,112,520,888};

inty,i,k,a=0,b=9;

for(i=0;i<10;i++) printf("%d",x[i]); scanf("%d",&y);

while(a<=b){//二分法查找

k=(b+a)/2; printf("x[%d]=%d\n",k,x[k]);

if(y==x[k])break;

if(y<x[k])b=k-1; elsea=k+1; }

if(a>b)printf("ERROR");

elseprintf("\nx[%d]=%d\n",k,x[k]);getch();}C語言數(shù)組講解4.2二維數(shù)組

4.2.1

二維數(shù)組的定義和初始化1.定義需要兩個下標才能標識數(shù)組中某個元素的位置,也稱為矩陣。Useatwo-dimensionalarrayiftwootheridentifiersareneededtodeterminethevalueofinterest.定義格式為:

類型定義符

數(shù)組名[常量表達式1][常量表達式2]/17列數(shù)行數(shù)inta[2][3];邏輯結構存儲結構C語言數(shù)組講解4.2.1

二維數(shù)組的定義和初始化2.二維數(shù)組的初始化和引用兩種初始化方式:按行初始化:每一對花括號對應一行的元素。按存放順序初始化:按內(nèi)存中的存放順序將初始值分別賦值給對應的元素。/17inta[2][3]={{1,2,3},{4,5,6}};inta[2][3]={1,2,3,4,5,6};inta[][3]={1,2,3,4,5,6};

C語言數(shù)組講解4.2.1

二維數(shù)組的定義和初始化/17intd[3][4]={{1},{2,3},{4,5,6}};intd[][4]={{1},{2,3},{4,5,6}};intd[3][4]={1,0,0,0,2,3,0,0,4,5,6};intd[][4]={1,0,0,0,2,3,0,0,4,5,6};inte[3][4]={{0,0,0,1},{0,0,2,3},{0,4,5,6}};inte[][4]={{0,0,0,1},{0,0,2,3},{0,4,5,6}};inte[3][4]={0,0,0,1,0,0,2,3,0,4,5,6}};C語言數(shù)組講解4.2.1

二維數(shù)組的定義和初始化3.二維數(shù)組在內(nèi)存中的存放M行N列的二維數(shù)組a,a[i][j]的位置公式為:i*N+j+1數(shù)組元素a[i][j]存儲映射關系為:a[i][j]a[0][N*i+j]/17Realcomputermemoryhasonlyonedimension,i.e.eachlocationisidentifiedwithonlyonecomponentofaddress.因此,二維數(shù)組元素可用它相對數(shù)組首元素[0][0]位置的偏移量來表示(稱為存儲映射關系storagemapping)。對二維數(shù)組元素的操作除了用二重循環(huán)外,還可以用一重循環(huán)實現(xiàn)。InC,oranyotherlanguagesupportingarrayswithdimensionsizesgreaterthanone,two-dimensionalarrayssimulatetheeffectofusingtwocomponentsofaddress.Todothis,thearrayismappedintoconsecutivememorywithrow0’svaluesfirst,thenrowone’svalues,etc.Youcanthinkofthisasasetofonedimensionalarraysholdingthecolumnvaluesasasinglevalueintherow’svalues.C語言數(shù)組講解二維數(shù)組元素的引用對二維數(shù)組inta[3][4]中各元素的輸出操作① for(i=0;i<3;i++)

for(j=0;j<4;j++) printf("%4d",a[i][j]);② for(i=0;i<3;i++)

for(j=0;j<4;j++)

//用相對a[0][0]位置的偏移量來表示printf("%4d",a[0][4*i+j]);③ for(i=0;i<12;i++)

//用相對a[0][0]位置的偏移量

printf("%4d",a[0][i]);/17C語言數(shù)組講解求矩陣特征值之和#defineN3main(){

inti,j,s=0,a[N][N]={{1,1,1},{2,1,1},{2,2,1}};

//顯示矩陣a[3][3] printf("對于矩陣a[%d][%d]\n",N,N);

for(i=0;i<N;i++){

for(j=0;j<N;j++) printf("%4d",a[i][j]); putch('\n'); } //主對角線元素之和

for(i=0;i<N;i++) s+=a[i][i]; printf("\n主對角線元素之和s=%d\n\n",s);二維數(shù)組的應用舉例——矩陣C語言數(shù)組講解

//副對角線元素之和

s=0;

for(i=0;i<N;i++) s+=a[i][N-1-i]; printf("副對角線元素之和s=%d\n\n",s); //上△元素之和

s=0;

for(i=0;i<N;i++)

for(j=i;j<N;j++) s+=a[i][j]; printf(“上△元素之和s=%d\n\n",s);

二維數(shù)組的應用舉例——矩陣(續(xù)1)C語言數(shù)組講解//下△元素之和

s=0;

for(i=0;i<N;i++)

for(j=0;j<=i;j++) s+=a[i][j]; printf("下△元素之和s=%d\n\n",s); //周邊元素之和

s=0;

for(i=0;i<N;i++)

for(j=0;j<N;j++)

if(i==0||i==N-1||j==0||j==N-1) s+=a[i][j]; printf("周邊元素之和s=%d\n\n",s); getch();}二維數(shù)組的應用舉例——矩陣(續(xù)2)C語言數(shù)組講解Tips:對于int型一維數(shù)組a和二維數(shù)組b

sizeof(a)/sizeof(int)

得到數(shù)組a的大小;

用sizeof(b)/sizeof(b[0])二維數(shù)組b的行數(shù)

sizeof(b[0])/sizeof(int)二維數(shù)組b的列數(shù)

【例】顯示二維數(shù)組b的各元素#include<stdio.h>main(){

intb[][4]={0,1,0,0,1,0,0,0,2,6,4},i,j;

for(i=0;i<sizeof(b)/sizeof(b[0]);i++){

for(j=0;j<sizeof(b[0])/sizeof(int);j++) printf("%5d",b[i][j]);printf("\n");;

}}二維數(shù)組的應用舉例——sizeof的使用C語言數(shù)組講解main(){

intx[4][3]={{1,2,3},{2,3,4},{3,4,5},{0,0,1}};

inti,j,k,row=0,column=0,min,m=4,n=3;

for(i=0;i<m;i++){//按行查找 max=x[i][0];

for(j=1;j<n;j++)//查找第i行的最大值

if(x[i][j]>max) max=x[i][j],row=i,column=j;

for(k=0;k<m;k++)//接下來判斷max是否本列最小值

if(x[k][column]<max)//如果不是則標記 { row=column=-1;break;}

if(row>-1&&column>-1){ printf("鞍點是該行上的最大值該列上的最小值\n");

printf("鞍點是x[%d][%d]=%d\n",row,column,max); }

} }應用舉例:求二維數(shù)組的鞍點saddlepoint,即該位置上的元素是該行上的最大值,是該列上的最小值。鞍點可能不存在C語言數(shù)組講解main(){ inta[5][3]={1,2,3,2,3,4,3,4,5,4,5,6,5,6,7}; inti,j,max[5],min[3]; //先把每行第1個數(shù)當最大值每列第1個數(shù)當最小值

for(i=0;i<5;i++)max[i]=a[i][0]; for(j=0;j<3;j++)min[j]=a[0][j];

//比對找出每行最大值和每列最小值 for(i=0;i<5;i++) for(j=0;j<3;j++){ if(a[i][j]>max[i])max[i]=a[i][j]; if(a[i][j]<min[j])min[j]=a[i][j];

}

//如最大值最小值是同1個數(shù),找到鞍點 for(i=0;i<5;i++)

for(j=0;j<3;j++)

if(max[i]==min[j]) printf("a[%d][%d]=%d是鞍點\n",i,j,a[i][j]);}尋找鞍點方法二:直接找出所有行的最大值所有列的最小值。一比對,若該行的最大值與該列的最小值相等,該位置的數(shù)就是鞍點。C語言數(shù)組講解4.2.3多維數(shù)組當需要用多個下標來確定數(shù)組元素時,數(shù)組稱為多維數(shù)組。Thereisnolimitinthelanguageastothenumberofdimensionsthatanarraymaybegiven.Eachdimensionrequiresasizespecifierwithinapairofbrackets.1. 多維數(shù)組的定義類型數(shù)組名[常量表達式1][常量表達式2]…[常量表達式n];【例如】定義一個整型三維數(shù)組:intb[2][3][4];b[0][0][0]b[0][0][1]b[0][0][2]b[0][0][3]

b[0][1][0]b[0][1][1]b[0][1][2]b[0][1][3]

b[0][2][0]b[0][2][1]b[0][2][2]b[0][2][3]

以下標0、1為變量i,下標0、1、2為變量j,下標0、1、2、3為變量k,就可以用三重循環(huán)結構對數(shù)組的每一個元素進行處理了。C語言數(shù)組講解多維數(shù)組初始化對于三維數(shù)組,可將其看作多個二維表格,即可以把它看成是由多個二維數(shù)組構成的。依此類推,一個n維數(shù)組可以看成是由多個n-1維數(shù)組構成的。前面數(shù)組b有24個元素,它們在內(nèi)存中排列順序跟二維數(shù)組類似:先變化第三個下標,然后變化第二個下標,最后變化第一個下標。

【例如】以三維數(shù)組初始化為例:

intb[2][3][4]={{{1,2,3,4},{5,6,7,8},{9,10,11,12}},

{{13,14,15,16},{17,18,19,20},{21,22,23,24}}};由第一維為2,可認為b數(shù)組由兩個二維數(shù)組組成,每個二維數(shù)組為3行4列。初始化時,對每個二維數(shù)組以按行初始化的方法,分別用花括號把各行元素值括起來,并且將三行的初值再用花括號括起來。C語言數(shù)組講解多維數(shù)組的一維表示多維數(shù)組元素也可用它相對數(shù)組首元素位置的偏移量來表示。三維數(shù)組b[L][M][N]的數(shù)組元素b[i][j][k]的存儲映射關系為:b[i][j][k]b[0][0][M*N*i+N*j+k]Example:intb[2][3][4];causesthecompilertoreservespacefor2arraysof3arraysof4integersincontiguousmemory.Thus24contiguousintegersarereserved.Astoragemappingfunctionisusedtotranslateanarrayreferenceintoapointerreference.Inthiscase,thestoragemappingfunctionmaps:

b[i][j][k]*(b[0][0][0]+3*4*i+4*j+k)C語言數(shù)組講解4.3字符型數(shù)組在C語言中,存儲字符串必須使用類型為char的字符型數(shù)組。字符型數(shù)組的每個數(shù)組元素存放一個字符的ASCII碼。字符串的結束標志是'\0'

。在存儲一個字符串時,系統(tǒng)自動在其末尾添加一個結束標志'\0'(數(shù)字0)。'\0'

不包括在字符串長度內(nèi)。ThestringinCprogramminglanguageisactuallyaone-dimensionalarrayofcharacterswhichisterminatedbyanullcharacter'\0'.例如,對于定義的字符數(shù)組chara[10]="Hello";Hello\0\0\0\0\0字符串結束符其余元素自動賦值為'

\0'C語言數(shù)組講解通常,一個字符串用一維字符型數(shù)組來存放,

多個字符串用二維字符型數(shù)組來存放。如果要將三個字符串置于字符數(shù)組s中"Howareyou"

"Goodmorning""Goodbye"

可定義為:chars[3][13];s[0]s[1]s[2]4.3字符型數(shù)組Howareyou\0\0Goodmorning\0Goodbye\0\0\0\0\0C語言數(shù)組講解4.3.1字符數(shù)組的初始化chara[]="abcde";charc[][5]={"Boy","Girl"};以下賦值語句也是合法的:chara[6]="abcde";chara[6]={"abcde"};chara[6]={'a','b','c','d','e'};chara[]={'a','b','c','d','e','\0'};charc[2][5]={"Boy","Girl"};charc[][5]={{"Boy"},{"Girl"}};charc[2][5]={{"Boy"},{"Girl"}};·C語言數(shù)組講解注意

(1)字符數(shù)組的長度應該大于實際存儲的字符串長度。否則按語法錯誤處理。(2)使用字符常量初始化時,如果字符末尾沒有'\0',則字符數(shù)組不能按字符串處理,只能對字符逐個進行處理。比如,數(shù)組a[]用單個字符來初始化,chara[5]={'a','b','c','d','e'};最后一個元素不是’\0’,它就不是字符串,就不能用字符串方法(如gets()、puts()、scanf()或printf()中%s格式)來操作。(3) 一維字符數(shù)組在初始化時,可以省略其長度,默認長度為初始化字符串的長度加1。如果沒有初始化賦值,則必須說明數(shù)組的長度。(4) 單引號是字符常量定界符,雙引號是字符串常量定界符。(5) 不能使用賦值語句將一個字符串常量或字符數(shù)組直接賦給一個字符數(shù)組。chara[5];a[]="abcde";//是錯誤的。4.3.1字符數(shù)組的初始化C語言數(shù)組講解字符數(shù)組的輸入─從鍵盤輸入的三種方法1、用gets函數(shù)輸入整個字符串

能輸入含空格字串并把回車轉成\0

2、在scanf函數(shù)中用格式符%s輸入整個字串

只能輸入不含空格符的字符串

chara[10];

scanf("%s",a);3、在scanf函數(shù)中用格式符%c逐個輸入字符

chara[12];inti;

for(i=0;i<12;i++)scanf("%c",&a[i]);a[12]=’\0’;chara[12];

gets(a);chars[3][13];int

i;for(i=0;i<3;i++)

gets(s[i]);C語言數(shù)組講解對于二維字符數(shù)組,可看成若干個一維字符數(shù)組(每個一維字符數(shù)組是一個字符串),使用時用二維字符數(shù)組行下標來表示二維字符數(shù)組中各個字符串的首地址。

main(){

char

s[3][13];

inti;

for(i=0;i<3;i++)

gets(s[i]);

for(i=0;i<3;i++)

printf("%s",s[i]);

}執(zhí)行時輸入:Howareyou

Goodmorning

Goodbye

程序中的s[i]

是一維數(shù)組名,它是一個地址常量。二維字符數(shù)組的輸入C語言數(shù)組講解字符數(shù)組的輸出─從屏幕輸出的三種方法1、puts函數(shù)輸出整個字符串

這種輸出方式遇到\0就自動換行

2、printf函數(shù)格式符%s輸出整個數(shù)組遇到遇到\0不換行

3、printf函數(shù)格式符%c逐個輸出數(shù)組元素chara[12]=“Howareyou”;puts(a);

chars[2][5]={"Boy","Girl"};

puts(s[0]);puts(s[1]);chara[12]="Howareyou";

printf("%s",a);chars[3][13]={"Howareyou","Good

morning","Goodbye"};

printf("%s\n",s[0]);

printf("%s\n",s[1]);

printf("%s\n",s[2]);

chars[12]="Howareyou";inti;

for(i=0;i<13;i++)printf("%c",s[i]);C語言數(shù)組講解

例:輸入0--99數(shù)字,顯示讀法(由于漢字為雙字節(jié)碼,所以不能用一維數(shù)組,要用二維數(shù)組。)main(){

intx,i,j,k;

char

a[11][3]={"零","壹","貳","叁","肆","伍","陸","柒",

"捌","玖","拾"}; scanf("%d",&x); i=x/10;//十位 j=x%10;//個位

if(i==0) printf("%s",a[j]);//個位數(shù)直接顯示

else

if(j==0) printf("%s%s",a[i],a[10]);//個位為0的十位數(shù)

else printf("%s%s%s",a[i],a[10],a[j]); getch();}

字符數(shù)組的應用舉例C語言數(shù)組講解4.3.4字符串函數(shù)在C語言中,由于字符串的處理通常要用字符數(shù)組,而字符數(shù)組名是地址常量不是變量(不能出現(xiàn)在賦值號的左邊),所以對字符串的連接、復制、比較等操作就比較麻煩。C語言提供了一些專門用于字符串處理的函數(shù),以方便用戶的使用。Csupportsawiderangeoffunctionsthatmanipulatenull-terminatedstrings,suchasstrlen(),strcat(),strcpy(),strcmp(),strlow()andstrupr().C語言數(shù)組講解常用的字符串處理函數(shù)1、測字串長度函數(shù)stringlengthstrlen()2、字串連接函數(shù)stringcaststrcat()3、字串復制函數(shù)stringcopystrcpy()

strncpy()4、字串比較函數(shù)stringcomparestrcmp()5、小寫轉換函數(shù)stringlowerstrlwr()6、大寫轉換函數(shù)stringupperstrupr()

因為字符串處理函數(shù)不是C語言的組成部分而是系統(tǒng)提供的公共函數(shù),因此調(diào)用字符串處理函數(shù)前,通常要加預編譯命令:

#include

<string.h>C語言數(shù)組講解strlen(字符數(shù)組)

測試字符串長度,不包含“\0”在內(nèi)。

例如:#include<string.h>main(){

chars[]="Howdoyoudo";

intc;c=strlen(s);printf("%d\n",c);}

運行結果是:13

改為

s[30]="Howdoyoudo\0"

運行結果也是13常用的字符串處理函數(shù)----求字符串長度C語言數(shù)組講解例:顯示一個字串中的大寫字母main(){

charc,s[30],i; printf("輸入一個字串:"); gets(s);

for(i=0;i<strlen(s);i++){

if(s[i]>='A'&&s[i]<='Z') printf("%c",s[i]); }}

常用的字符串處理函數(shù)--求字符串長度函數(shù)舉例C語言數(shù)組講解例:指針表示法顯示一個字串中的大寫字母main(){

charc,s[30],*p; printf("輸入一個字串:"); gets(s);

for(p=s;p-s<strlen(s);p++){

if(*p>='A'&&*p<='Z') printf("%c",*p); }}C語言數(shù)組講解連接兩個字符數(shù)組中的字符串:

把字符數(shù)組2接在字符數(shù)組1的后面,放到字符數(shù)組1中,并得到一個函數(shù)值,該函數(shù)值是字符數(shù)組的起始地址。注1:字符數(shù)組1必須足夠大;注2:字符數(shù)組2也可以是一個字符串常量。常用的字符串處理函數(shù)----字符串連接strcat(字符數(shù)組1,字符數(shù)組2)

C語言數(shù)組講解例如

#include<string.h>main(){

charc[30]="abcde\n",s[20]="Howdoyoudo";

strcat(c,s);

/*將S接在C的后邊*/

printf("%s\n",c);}運行結果是:

abcdeHowdoyoudostrcat(c,"Howdoyoudo");

printf("%s\n",c);}

常用的字符串處理函數(shù)----字符串連接舉例C語言數(shù)組講解strcpy(t,a);strcpy(a,b);strcpy(b,t);常用的字符串處理函數(shù)----字符串拷貝將字符數(shù)組2拷貝到字符數(shù)組1中。復制后的結果放在字符數(shù)組1中,字符數(shù)組2不變。函數(shù)值是字符數(shù)組1的地址。

字符數(shù)組1必須寫成數(shù)組名形式,如s。字符數(shù)組2可以是字符數(shù)組名,也可以是一個字符串常量。說明:

(1)字符數(shù)組1定義時其長度要大于等于字符數(shù)組2的長度。

(2)復制時連同字串2中的’\0’一起被復制到字串1中。

(3)若字符數(shù)組1中原存有字符,則原有字符不再存在。字串間的賦值不能用a=b;只能用strcpy(a,b)strcpy(字符數(shù)組1,字符數(shù)組2)

C語言數(shù)組講解strncpy(字符數(shù)組1,字符數(shù)組2,n)將字符數(shù)組2的前n個字符拷貝到字符數(shù)組1中。復制后的結果放在字符數(shù)組1中,字符數(shù)組2不變。函數(shù)值是字符數(shù)組1的地址。

例如:

main(){

chara[]="helloworld!"; strncpy(a,"HELLOWORLD!",2); puts(a); getch(); }顯示:HElloworld!常用的字符串處理函數(shù)----字符串拷貝C語言數(shù)組講解strcmp(字符串1,字符串2)

如果兩個字符串一樣大,函數(shù)值為0;

如果字符串1大,函數(shù)值為一正整數(shù);

如果字符串2大,函數(shù)值為負整數(shù)。對于字符數(shù)組a和b而言:

strcmp(a,b)==0a、b兩字串相等

strcmp(a,b)>0a字串>b字串

strcmp(a,b)<0a字串<b字串(字符串比大小,按ASCII碼比較,先比第1個字符。)

常用的字符串處理函數(shù)----字符串比較C語言數(shù)組講解#include<string.h>main(){

charc[7]="abcdef",s[4]="abc",t[]="acb";inta,b;a=strcmp(c,s);b=strcmp(c,s);printf("%d\n%d",a,b);}

常用的字符串處理函數(shù)----字符串比較舉例在TC2.0中的運行結果:

100-1在VC++中的運行結果:

1-1C語言數(shù)組講解數(shù)據(jù)比較時應注意判斷兩個字符串是否相等時:

不能使用if(a==b)

應使用if(strcmp(a,b)==0)

相等比較的總結字符串

strcmp(a,b)==0整數(shù)

a==b實數(shù)

fabs(a-b)<1e-6C語言數(shù)組講解例如main(){

inti=0;

chara[]="abcd",b[]="abcd";

if(a==b)printf("Yes");

elseprintf("No");}結果居然是No,將if語句改為:if(strcmp(a,b)==0)后,結果就為Yes。

字符串比較時應注意C語言數(shù)組講解strlwr(字符串)

將字符串中的大寫字母轉換成小寫字母strupr(字符串)

將字符串中的小寫字母轉換成大寫字母

例:大小寫轉換函數(shù)應用main(){

char

s[100];gets(s);strupr(s);puts(s);strlwr(s);puts(s);}常用的字符串處理函數(shù)----字母大小寫轉換C語言數(shù)組講解#include<string.h>main(){

chara[]="wang",b[]="1234",user[100],psw[100];

do{ system("cls"); printf("請輸入用戶名"); gets(user);strlwr(user); printf("請輸入密碼"); gets(psw); }while(strcmp(a,user)!=0||strcmp(b,psw)!=0); printf("\n歡迎您:%s",user);}字符串應用舉例:用戶名和密碼的驗證IC語言數(shù)組講解#include<string.h>main(){

chara[]="wang",b[]="1234",user[100],psw[100];inti; do{

system("cls"); printf("請輸入用戶名"); gets(user);strlwr(user); printf("請輸入密碼"); i=-1; do{ i++; psw[i]=getch(); putch('*'); }while(psw[i]!=13); psw[i]='\0'; }while(strcmp(a,user)!=0||strcmp(b,psw)!=0); printf("\n歡迎您:%s",user);}字符串應用舉例:用戶名和密碼的驗證IIC語言數(shù)組講解#include<string.h>main(){

chara[10][20]={"廣州","武漢","上海","北京","成都","太原","鄭州","南京","石家莊","天津"},t[20];

inti,j;

for(i=0;i<9;i++)

for(j=i+1;j<10;j++)

if(strcmp(a[i],a[j])>0) strcpy(t,a[i]), strcpy(a[i],a[j]), strcpy(a[j],t);

for(i=0;i<10;i++) printf("%s\t",a[i]);}字符串應用舉例:字符串的排序C語言數(shù)組講解4.4指針和數(shù)組指針的應用與數(shù)組是密不可分的。數(shù)組a的指針是指數(shù)組a的起始地址,即&a[0],數(shù)組元素的指針就是該數(shù)組元素的地址。

inta[6];

int*p=a;

&a[0]&a[1]&a[2]&a[3]&a[4]&a[5]a+0a+1a+2a+3a+4a+5p+0p+1p+2p+3p+4p+5a[0]a[1]a[2]a[3]a[4]a[5]實際上,下標表達式a[i]就是按照指針表達式*(a+i)定義的。C語言數(shù)組講解指向數(shù)組的指針變量的賦值方法

方法1:在定義指針變量時賦值。inta[10],*p=a;方法2:在定義指針變量后賦值。inta[10],*p;p=a;結果:p是數(shù)組a的指針,指向a

數(shù)組的第一個元素a[0]的首地址

main(){

inti,a[6]={0,1,2,3,4,5},*p; p=a;

for(i=0;i<6;i++) printf("%d",a[i]);}可替換為*(a+i)或*(p+i)C語言數(shù)組講解在程序中使用指針變量時應當注意

指針的變化

++--

使指針按它所指向的類型所規(guī)定的字節(jié)數(shù)在內(nèi)存區(qū)中移動(跳動而不是滑動)。

指針變量的運算

++和*是同優(yōu)先級,從右至左的結合方向。

*p++和*(p++)等價*++p和*(++p)等價③

(*p)++表示p所指向的元素值加1。C語言數(shù)組講解通過指針的算術運算引用數(shù)組元素指向數(shù)組的指針可以指向數(shù)組中的其它元素。main(){inta[10]={2,4,5,8};

int*p=a;//p指向a[0]printf(“%4d”,*p++);//輸出a[0],p指向a[1]printf(“%4d”,*p++);//輸出a[1],p指向a[2]printf(“%4d”,*p++);//輸出a[2],p指向a[3]printf(“%4d”,*p++);//輸出a[3],p指向a[4]}運行結果是:2458

C語言數(shù)組講解用*p++遍歷整個數(shù)組main(){

inta[]={9,8,7,6,5,4,3,2,1,0},*p=a,i;

for(i=0;i<sizeof(a)/sizeof(int);i++) printf("%d",*p++); getch();}注意:

這種方法造成了指針p的移動。C語言數(shù)組講解同樣,可以用p++和地址偏移量遍歷整個數(shù)組main(){

inta[10]={9,8,7,6,5,4,3,2,1,0},*p;

for(p=a;p-a<10;p++) printf(“%d,",*p);}運行結果:9,8,7,6,5,4,3,2,1,

其中p中存放的是地址,p-a<10表示p單元中的值減去數(shù)組a的首地址所得的單元數(shù)不超過10。注意:

這種方法也造成了指針p的移動用p++與地址偏移量遍歷整個數(shù)組C語言數(shù)組講解通過帶下標的指針變量引用數(shù)組元素指向數(shù)組的指針變量也可以帶下標定義了:inta[10],*p=a;

后:

可以使用a[i]

或 p[i]

或 *(a+i)

或 *(p+i)這4種方法引用a數(shù)組中的第i個元素。注意:這些方法都不造成指針p的移動。C語言數(shù)組講解輸出數(shù)組元素四種方法main(){

inta[10]={10,9,8,7,6,5,4,3,2,1},*p,i; p=a;

for(i=0;i<10;i++) printf("%d",a[i]); putch('\n');

for(i=0;i<10;i++) printf("%d",p[i]); putch('\n');

for(i=0;i<10;i++) printf("%d",*(a+i)); putch('\n');

for(i=0;i<10;i++) printf("%d",*(p+i));}C語言數(shù)組講解利用指針變量對數(shù)組元素賦值通過指針變量p實現(xiàn)數(shù)組元素的賦值:inta[5],*p=a,i;

for(i=0;i<5;i++){ printf("a[%d]=",i); scanf("%d",&a[i]); }

可替換成&p[i]或a+i或p+i或p++利用p++和地址偏移量p-a實現(xiàn)數(shù)組元素的賦值for(p=a;p-a<5;p++){printf("a[%d]=",p-a);scanf("%d",p);}C語言數(shù)組講解總結:數(shù)組遍歷的6種方法造成指針p的移動的2種方法(p必須初始化)*p++p++配合*p不造成指針p的移動的4種方法*(p+i)p[i]*(a+i)a[i]

數(shù)組在C語言中是個二等公民:不能作為整體操作數(shù)組。但將指針變量指向一個數(shù)組后,就可以用對指針變量的操作去整體操作一個數(shù)組了。C語言數(shù)組講解在程序中使用指針變量時應當注意

常見的指針變量運算*(++p) 先移指針,取出下一個單元的值。*(p++) 先取出當前單元的值,再移指針。

(*p)++ 先取出當前單元值,再使當前單元加1。

不移指針。

++(*p) 先使前單元的值加1,再取出。不移指針。注意:*p++和*(p++)是等價的。

數(shù)組和指針的統(tǒng)一性是C語言的長處之一。用指針可以很方便地訪問數(shù)組和模擬動態(tài)分配的數(shù)組。但是,說數(shù)組和指針等價并不表示它們相同,甚至也不能互換?!暗葍r”的意思是:指針算術和數(shù)組下標運算等價,指針和數(shù)組是不同的。(WayneThroop)C語言數(shù)組講解遍歷數(shù)組時指針的移動在用指針變量遍歷數(shù)組時,要特別注意指針是否移動。main(){

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論