《C語言程序設(shè)計》課件-第6章 數(shù)組_第1頁
《C語言程序設(shè)計》課件-第6章 數(shù)組_第2頁
《C語言程序設(shè)計》課件-第6章 數(shù)組_第3頁
《C語言程序設(shè)計》課件-第6章 數(shù)組_第4頁
《C語言程序設(shè)計》課件-第6章 數(shù)組_第5頁
已閱讀5頁,還剩53頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

6.1一維數(shù)組第6章數(shù)組思政目標(biāo)1、培養(yǎng)科學(xué)精神與理性思維通過理解數(shù)組的定義、引用和操作規(guī)則,如嚴(yán)格按照下標(biāo)訪問元素等,培養(yǎng)學(xué)生嚴(yán)謹(jǐn)、細(xì)致的科學(xué)態(tài)度。在處理數(shù)組相關(guān)問題時,要求學(xué)生運用邏輯推理分析問題,像在數(shù)組排序等算法中準(zhǔn)確把握步驟和條件,從而提升理性思維能力,使其在面對各類問題時能依據(jù)科學(xué)規(guī)律和邏輯方法思考解決。2、增強創(chuàng)新意識與實踐能力學(xué)習(xí)數(shù)組知識后,鼓勵學(xué)生在解決實際問題中創(chuàng)新應(yīng)用,如對數(shù)據(jù)的獨特存儲和處理方式。通過實際編程實踐,如完成課件中的各種數(shù)組應(yīng)用程序舉例,讓學(xué)生在實踐中不斷嘗試新方法、新思路,提高動手能力,將理論知識轉(zhuǎn)化為實際成果,進(jìn)而培養(yǎng)創(chuàng)新意識,為應(yīng)對未來社會發(fā)展中的挑戰(zhàn)做好準(zhǔn)備。6.1一維數(shù)組第六章數(shù)組構(gòu)造數(shù)據(jù)類型之一數(shù)組:有序數(shù)據(jù)的集合,用數(shù)組名標(biāo)識元素:屬同一數(shù)據(jù)類型,用數(shù)組名和下標(biāo)確定6.1

一維數(shù)組一維數(shù)組的定義定義方式:數(shù)據(jù)類型數(shù)組名[常量表達(dá)式];

合法標(biāo)識符表示元素個數(shù)下標(biāo)從0開始[]:數(shù)組運算符單目運算符優(yōu)先級(1)左結(jié)合不能用()例

inta[6];a[0]0145a[1]a[2]a[3]a[4]a[5]23a編譯時分配連續(xù)內(nèi)存內(nèi)存字節(jié)數(shù)=數(shù)組維數(shù)*

sizeof(元素數(shù)據(jù)類型)數(shù)組名表示內(nèi)存首地址,是地址常量一維數(shù)組的引用數(shù)組必須先定義,后使用只能逐個引用數(shù)組元素,不能一次引用整個數(shù)組數(shù)組元素表示形式:數(shù)組名[下標(biāo)]其中:下標(biāo)可以是常量或整型表達(dá)式例inti=15;intdata[i];(

不能用變量定義數(shù)組維數(shù))例inta[10];printf(“%d”,a);(

)必須

for(j=0;j<10;j++)printf(“%d\t”,a[j]);(

)例intdata[5];data[5]=10;//C語言對數(shù)組不作越界檢查,使用時要注意一維數(shù)組的初始化初始化方式在定義數(shù)組時,為數(shù)組元素賦初值(在編譯階段使之得到初值)inta[5]={1,2,3,4,5};等價于:a[0]=1;a[1]=2;a[2]=3;a[3]=4;a[4]=5;說明:數(shù)組不初始化,其元素值為隨機(jī)數(shù)對static數(shù)組元素不賦初值,系統(tǒng)會自動賦以0值當(dāng)全部數(shù)組元素賦初值時,可不指定數(shù)組長度如inta[5]={6,2,3};

等價于:a[0]=6;a[1]=2;a[2]=3;a[3]=0;a[4]=0;如inta[3]={6,2,3,5,1};(

)staticinta[5];等價于:a[0]=0;a[1]=0;a[2]=0;a[3]=0;a[4]=0;只給部分?jǐn)?shù)組元素賦初值

inta[]={1,2,3,4,5,6};編譯系統(tǒng)根據(jù)初值個數(shù)確定數(shù)組維數(shù)程序舉例例1讀10個整數(shù)存入數(shù)組,找出其中最大值和最小值步驟:1.輸入:for循環(huán)輸入10個整數(shù)2.處理:(a)先令max=min=x[0](b)依次用x[i]和max,min比較(循環(huán))若max<x[i],令max=x[i]

若min>x[i],令min=x[i]3.輸出:max和min#include<stdio.h>#defineSIZE10main(){intx[SIZE],i,max,min;printf("Enter10integers:\n");

for(i=0;i<SIZE;i++){printf("%d:",i+1); scanf("%d",&x[i]);}

max=min=x[0];

for(i=1;i<SIZE;i++){if(max<x[i])max=x[i];if(min>x[i])min=x[i];}printf("Maximumvalueis%d\n",max);printf("Minimumvalueis%d\n",min);}程序舉例例2讀10個整數(shù)存入數(shù)組,找出其中最小值以及其所在位置。步驟:1.輸入:for循環(huán)輸入10個整數(shù)2.處理:(a)先令min=x[0],k=0;(b)依次用x[i]和min比較(循環(huán))若min>x[i],令min=x[i],k=i3.輸出:min和k#include<stdio.h>#defineSIZE10main(){intx[SIZE],i,max,min,k;printf("Enter10integers:\n");

for(i=0;i<SIZE;i++){printf("%d:",i+1); scanf("%d",&x[i]);}min=x[0];k=0;

for(i=1;i<SIZE;i++)if(min>x[i]){min=x[i];k=i;}printf("Minimumvalueis%d,Minimumlocationis%d\n",min,k);}程序舉例例2讀10個整數(shù)存入數(shù)組,找出其中最小值以及其所在位置。步驟:1.輸入:for循環(huán)輸入10個整數(shù)2.處理:(a)先令k=0;(b)依次用x[i]和min比較(循環(huán))若x[k]>x[i],令k=i3.輸出:x[k]和k#include<stdio.h>#defineSIZE10main(){intx[SIZE],i,max,min,k;printf("Enter10integers:\n");

for(i=0;i<SIZE;i++){printf("%d:",i+1); scanf("%d",&x[i]);}k=0;

for(i=1;i<SIZE;i++)if(x[k]>x[i]){k=i;}printf("Minimumvalueis%d,Minimumlocationis%d\n",x[k],k);}例3用數(shù)組求Fibonacci數(shù)列前20個數(shù)f[0]f[1]f[2]f[3]f[4]f[5]f[19]……...11f[19]01452319235#include<stdio.h>main(){inti;

intf[20]={1,1};

for(i=2;i<20;i++)f[i]=f[i-2]+f[i-1];

for(i=0;i<20;i++){if(i%5==0)printf("\n");printf("%12d",f[i]);}}例4用冒泡法對10個數(shù)排序排序過程:(1)比較第一個數(shù)與第二個數(shù),若為逆序a[0]>a[1],則交換;然后比較第二個數(shù)與第三個數(shù);依次類推,直至第n-1個數(shù)和第

n個數(shù)比較為止——第一趟冒泡排序,結(jié)果最大的數(shù)被安置在最后一個元素位置上(2)對前n-1個數(shù)進(jìn)行第二趟冒泡排序,結(jié)果使次大的數(shù)被安置在第n-1個元素位置(3)重復(fù)上述過程,共經(jīng)過n-1趟冒泡排序后,排序結(jié)束例3849657613273097第一趟38496513273076第二趟384913273065第三趟3813273049第四趟13273038第五趟132730第六趟4938659776132730初始關(guān)鍵字n=8384976971397279730971376767627301365276530651313494930492738273830381327第七趟輸入n個數(shù)給a[1]到a[n]forj=1ton-1fori=1ton-ja[i]>a[i+1]真假a[i]

a[i+1]輸出a[1]到a[n]#include<stdio.h>#defineN10main(){inta[N],i,j,t;printf("Input10numbers:\n");

for(i=0;i<N;i++)scanf("%d",&a[i]);printf("\n");

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

if(a[i]>a[i+1]){t=a[i];a[i]=a[i+1];a[i+1]=t;}printf("Thesortednumbers:\n");

for(i=0;i<N;i++) printf("%d",a[i]);}例5用簡單選擇法對10個數(shù)排序排序過程:(1)首先通過n-1次比較,從n個數(shù)中找出最小的,將它與第一個數(shù)交換—第一趟選擇排序,結(jié)果最小的數(shù)被安置在第一個元素位置上;(2)再通過n-2次比較,從剩余的n-1個數(shù)中找出關(guān)鍵字次小的記錄,將它與第二個數(shù)交換—第二趟選擇排序;(3)重復(fù)上述過程,共經(jīng)過n-1趟排序后,排序結(jié)束。例初始:[49386597761327]kji=11349一趟:13[386597764927]i=22738二趟:1327[6597764938]三趟:132738[97764965]四趟:13273849[769765]五趟:1327384965[9776]六趟:132738496576[97]kkkkjjjjjjjjjj輸入n個數(shù)給a[1]到a[n]fori=1ton-1forj=i+1tona[j]<a[k]真假k=j輸出a[1]到a[n]k=ia[i]

a[k]i!=k真假#include<stdio.h>#defineN10main(){inta[N],i,j,k,x;printf("Input10numbers:\n");

for(i=0;i<N;i++)scanf("%d",&a[i]);printf("\n");

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

{k=i;

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

if(a[j]<a[k])k=j;

if(i!=k){x=a[i];a[i]=a[k];a[k]=x;}

}printf("Thesortednumbers:\n");

for(i=0;i<N;i++) printf("%d",a[i]);}#include"stdio.h"#defineN6main(){inta[N],b['B'-60],c[]={1,2,3,4,5,6},i;for(i=0;i<N;i++)scanf("%d%d",&a[i],&b[i]);for(i=0;i<N;i++)printf("%d",a[i]);printf("\n");for(i=0;i<N;i++)printf("%d",b[i]);printf("\n");for(i=0;i<N;i++)c[i]=a[i]+b[N-i-1];for(i=0;i<N;i++)printf("%d",c[i]);}數(shù)組定義:必須用常量表達(dá)式數(shù)組元素引用6.2二維數(shù)組及多維數(shù)組第6章數(shù)組思政目標(biāo)1、培養(yǎng)邏輯思維與空間想象能力理解二維及多維數(shù)組的結(jié)構(gòu)與存儲方式,需運用邏輯思維把握元素間關(guān)系,如同在復(fù)雜情境中分析問題。通過想象數(shù)組元素在多維空間的分布,如行序優(yōu)先存儲,鍛煉空間想象能力,為學(xué)習(xí)立體幾何等知識奠基,助力學(xué)生以理性思維和空間感知應(yīng)對生活與學(xué)業(yè)挑戰(zhàn)。2、增強合作意識與創(chuàng)新精神多維數(shù)組相關(guān)編程任務(wù)具挑戰(zhàn)性,鼓勵學(xué)生分組合作攻克難題,交流中激發(fā)創(chuàng)新思維,探尋獨特算法與應(yīng)用場景。培養(yǎng)合作意識,讓學(xué)生明白團(tuán)隊力量,學(xué)會傾聽與互補。創(chuàng)新精神使其勇于嘗試新方法,提高實踐能力,為未來發(fā)展積蓄力量。6.2二維數(shù)組及多維數(shù)組6.2

二維數(shù)組及多維數(shù)組二維數(shù)組的定義定義方式:

數(shù)據(jù)類型數(shù)組名[常量表達(dá)式][常量表達(dá)式];數(shù)組元素的存放順序原因:內(nèi)存是一維的二維數(shù)組:按行序優(yōu)先多維數(shù)組:最右下標(biāo)變化最快例inta[3][4];floatb[2][5];intc[2][3][4];

inta[3,4];(

)行數(shù)列數(shù)元素個數(shù)=行數(shù)*列數(shù)inta[3][2]a[0][1]a[1][0]a[1][1]a[2][0]a[2][1]014523a[0][0]a[0][0]a[0][1]a[1][0]a[1][1]a[2][0]a[2][1]intc[2][3][4]01234567………...20212223c[0][0][0]c[0][0][1]c[0][0][2]c[0][0][3]c[0][1][0]c[0][1][1]c[0][1][2]c[0][1][3]c[0][2][0]c[0][2][1]c[0][2][2]c[0][2][3]c[1][0][0]c[1][0][1]c[1][0][2]c[1][0][3]c[1][1][0]c[1][1][1]c[1][1][2]c[1][1][3]c[1][2][0]c[1][2][1]c[1][2][2]c[1][2][3]二維數(shù)組理解例inta[3][4];20161720181920202120222320089201011201213201415200012002320045200067a[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[i]由包含4個元素的一維數(shù)組組成二維數(shù)組a是由3個元素組成a[0]a[1]a[2]行名014523a[0][1]a[0][2]a[0][3]a[1][0]a[1][1]a[0][0]a[1][3]a[2][0]a[2][1]a[2][2]a[2][3]a[1][2]67101189a[0]a[1]a[2]二維數(shù)組元素的引用形式:數(shù)組名[下標(biāo)][下標(biāo)]二維數(shù)組元素的初始化分行初始化:

例inta[2][3]={{1,2,3},{4,5,6}};a[0][0]a[0][1]a[0][2]a[1][0]a[1][1]a[1][2]123456全部初始化按元素排列順序初始化

例inta[2][3]={{1,2},{4}};a[0][0]a[0][1]a[0][2]a[1][0]a[1][1]a[1][2]120400部分初始化

例inta[][3]={{1},{4,5}};a[0][0]a[0][1]a[0][2]a[1][0]a[1][1]a[1][2]100450第一維長度省略初始化

例inta[2][3]={1,2,3,4,5,6};a[0][0]a[0][1]a[0][2]a[1][0]a[1][1]a[1][2]123456全部初始化

例inta[2][3]={1,2,4};a[0][0]a[0][1]a[0][2]a[1][0]a[1][1]a[1][2]124000部分初始化

例inta[][3]={1,2,3,4,5};a[0][0]a[0][1]a[0][2]a[1][0]a[1][1]a[1][2]123450第一維長度省略初始化程序舉例例1將二維數(shù)組行列元素互換,存到另一個數(shù)組中a=123456b=142536#include<stdio.h>main(){inta[2][3]={{1,2,3},{4,5,6}};intb[3][2],i,j;printf("arraya:\n");

for(i=0;i<=1;i++){for(j=0;j<=2;j++) {printf("%5d",a[i][j]); b[j][i]=a[i][j]; } printf("\n");}printf("arrayb:\n");

for(i=0;i<=2;i++){for(j=0;j<=1;j++) printf("%5d",b[i][j]);printf("\n");}}例2求二維數(shù)組中最大元素值及其行列號max=a[0][0]fori=0to2forj=0to3a[i][j]>max真假max=a[i][j]row=icolum=j輸出:max和row,colum#include<stdio.h>main(){inta[3][4]={{1,2,3,4},{9,8,7,6},{-10,10,-5,2}};inti,j,row=0,colum=0,max;

max=a[0][0];

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

if(a[i][j]>max)

{max=a[i][j]; row=i; colum=j; }printf("max=%d,row=%d,\colum=%d\n",max,row,colum);}例3讀入下表中值到數(shù)組,分別求各行、各列及表中所有數(shù)之和124615798233251712462215793182333425172437

39

35

111#include<stdio.h>main(){intx[5][4],i,j;

for(i=0;i<4;i++)for(j=0;j<3;j++)scanf("%d",&x[i][j]);

for(i=0;i<3;i++)x[4][i]=0;for(j=0;j<5;j++)x[j][3]=0;

for(i=0;i<4;i++)for(j=0;j<3;j++){x[i][3]+=x[i][j];x[4][j]+=x[i][j];x[4][3]+=x[i][j];}for(i=0;i<5;i++){for(j=0;j<4;j++)printf("%5d\t",x[i][j]);printf("\n");}}6.3字符數(shù)組和字符串第6章數(shù)組思政目標(biāo)1、嚴(yán)謹(jǐn)思維與規(guī)則意識字符數(shù)組和字符串的操作需嚴(yán)格遵循特定規(guī)則,如初始化方式、輸入輸出格式及處理函數(shù)的使用條件等。這培養(yǎng)學(xué)生嚴(yán)謹(jǐn)?shù)乃季S習(xí)慣,使其明白在處理信息時必須精準(zhǔn)細(xì)致,如同遵循社會規(guī)則和道德規(guī)范,增強規(guī)則意識,提高處理復(fù)雜問題的準(zhǔn)確性。2、文化傳承與創(chuàng)新表達(dá)字符串作為信息載體,能傳遞豐富文化內(nèi)涵。學(xué)生通過編程處理字符串,如進(jìn)行文本分析、信息展示等,不僅能深入理解文化內(nèi)容,還能在創(chuàng)新應(yīng)用中以新方式表達(dá)文化元素,促進(jìn)文化傳承與創(chuàng)新,提升文化自信,同時培養(yǎng)創(chuàng)新精神和實踐能力。6.3字符數(shù)組和字符串6.3

字符數(shù)組和字符串字符數(shù)組定義字符數(shù)組的初始化逐個字符賦值用字符串常量字符數(shù)組的引用例charc[10],ch[3][4];

例charch[5]={‘H’,’e’,’l’,’l’,’o’};ch[0]Hello逐個字符賦值ch[1]ch[2]ch[3]ch[4]有問題!

例charch[5]={‘H’,’e’,’l’,’l’,’o’};ch[0]Hello逐個字符賦值ch[1]ch[2]ch[3]ch[4]

例charch[5]={‘B’,’o’,’y’};ch[0]Boy\0\0逐個字符賦值ch[1]ch[2]ch[3]ch[4]

例charch[5]=“Boy”;ch[0]Boy\0\0用字符串常量ch[1]ch[2]ch[3]ch[4]

例charch[6]={“Hello”};charch[6]=“Hello”;charch[]=“Hello”;用字符串常量ch[0]Helloch[1]ch[2]ch[3]ch[4]\0ch[5]

例chardiamond[][5]={{'.','.','*'},{'.','*','.','*'}, {'*','.','.','.','*'},{'.','*','.','*'},{'.','.','*'}};二維字符數(shù)組初始化..*\0\0.*.*\0*...*.*.*\0..*\0\0diamond[0]diamond[1]diamond[2]diamond[3]diamond[4]

charfruit[][7]={“Apple”,”O(jiān)range”,”Grape”,”Pear”,”Peach”};二維字符數(shù)組初始化fruit[0]fruit[1]fruit[2]fruit[3]fruit[4]Apple\0\0Orange\0Grape\0\0Pear\0\0\0Peach\0\0例

輸出一個字符串#include<stdio.h>main(){charc[10]={'I','','a','m','','a','','b','o','y'};inti;for(i=0;i<10;i++)printf("%c",c[i]);printf("\n");}Iamaboy0123456789字符串字符串及其結(jié)束標(biāo)志無字符串變量,用字符數(shù)組處理字符串字符串結(jié)束標(biāo)志:‘\0’例“hello”共5個字符,在內(nèi)存占6個字節(jié)字符串長度5

hello\01041011081081110內(nèi)存存放字符ASCII碼字符串的輸入輸出逐個字符I/O:%c整個字符串I/O:%s例用%cmain(){charstr[5];inti;for(i=0;i<5;i++)scanf(“%c”,&str[i]);for(i=0;i<5;i++)printf(“%c”,str[i]);}例用%smain(){charstr[5];scanf(“%s”,str);printf(“%s”,str);}用字符數(shù)組名,不要加&輸入串長度<數(shù)組維數(shù)遇空格或回車結(jié)束自動加‘\0’用字符數(shù)組名,遇‘\0’結(jié)束例main(){chara[5]={'H','e','l','l','o'};printf("%s",a);}例main(){chara[]=“Hello”;printf(“%s”,a);}結(jié)果:Hello#-=*

hello02314結(jié)果:Hello用“%s”輸出時,遇‘\0’結(jié)束main(){chara[]={'h','e','l','\0','l','o','\0'};printf("%s",a);}例輸出:hel

hel\0lo\0數(shù)組中有多個‘\0’時,遇第一個結(jié)束main(){inti;chara[5];scanf("%s",a);for(i=0;i<5;i++)printf("%d,",a[i]);}運行情況:(1)若輸入hel,正常(2)若輸入hell,正常(3)若輸入hello,用%s輸出時,會出現(xiàn)問題

hel\0

hell\0

hello輸入字符串長度<數(shù)組維數(shù)例字符串輸入舉例

How\0

are\0

you?\0

#include<stdio.h>main(){chara[15],b[5],c[5];

scanf("%s%s%s",a,b,c);printf("a=%s\nb=%s\nc=%s\n",a,b,c);

scanf("%s",a);printf("a=%s\n",a);}運行情況:輸入:Howareyou?輸出:a=Howb=arec=you?輸入:Howareyou?輸出:a=Howscanf中%s輸入時,遇空格或回車結(jié)束運行情況:輸入:Howareyou?例若準(zhǔn)備將字符串“Thisisastring.”記錄下來,錯誤的輸入語句為:(A)scanf(“%20s”,s);(B)for(k=0;k<17;k++)s[k]=getchar();(C)while((c=getchar())!=‘\n’)s[k++]=c;常用的字符串處理函數(shù)包含在頭文件string.h字符串輸出函數(shù)puts格式:puts(字符數(shù)組)功能:向顯示器輸出字符串(輸出完,換行)說明:字符數(shù)組必須以‘\0’結(jié)束字符串輸入函數(shù)gets格式:gets(字符數(shù)組)功能:從鍵盤輸入一以回車結(jié)束的字符串放入字符數(shù)組中,并自動加‘\0’說明:輸入串長度應(yīng)小于字符數(shù)組維數(shù)例#include<stdio.h>main(){charstring[80];printf(“Inputastring:”);gets(string);puts(string);}輸入:Howareyou?輸出:Howareyou?

字符串連接函數(shù)strcat格式:strcat(字符數(shù)組1,字符數(shù)組2)功能:把字符數(shù)組2連到字符數(shù)組1后面返值:返回字符數(shù)組1的首地址說明:字符數(shù)組1必須足夠大連接前,兩串均以‘\0’結(jié)束;連接后,串1的‘\0’取消,新串最后加‘\0’字符串拷貝函數(shù)strcpy格式:strcpy(字符數(shù)組1,字符串2)功能:將字符串2,拷貝到字符數(shù)組1中去返值:返回字符數(shù)組1的首地址說明:字符數(shù)組1必須足夠大拷貝時‘\0’一同拷貝

不能使用賦值語句為一個字符數(shù)組賦值例charstr1[20],str2[20];str1={“Hello!”};(

)str2=str1;(

)例strcpy與strcat舉例#include<string.h>#include<stdio.h>voidmain(){chardestination[25];charblank[]="",c[]="C++",turbo[]="Turbo";

strcpy(destination,turbo);

strcat(destination,blank);

strcat(destination,c);printf("%s\n",destination);}TurboC++TrboC++0123456789u\024…….Trbo0123456789u\024…….…….Trbo\00123456789u24…….…...字符串比較函數(shù)strcmp格式:strcmp(字符串1,字符串2)功能:比較兩個字符串比較規(guī)則:對兩串從左向右逐個字符比較(ASCII碼),直到遇到不同字符或‘\0’為止返值:返回int型整數(shù),a.若字符串1<字符串2,返回負(fù)整數(shù)

b.若字符串1>字符串2,返回正整數(shù)

c.若字符串1==字符串2,返回零說明:字符串比較不能用“==”,必須用strcmp字符串長度函數(shù)strlen格式:strlen(字符數(shù)組)功能:計算字符串長度返值:返回字符串實際長度,不包括‘\0’在內(nèi)例對于以下字符串,strlen(s)的值為:(1)chars[10]={‘A’,‘\0’,‘B’,‘C’,‘\0’,‘D’};(2)chars[]=“\t\v\\\0will\n”;(3)chars[]=“\x69\082\n”;答案:131#include<string.h>#include<stdio.h>main(){charstr1[]=”Hello!",str2[]=”Howareyou?”,str[20];intlen1,len2,len3;

len1=strlen(str1);len2=strlen(str2);

if(strcmp(str1,str2)>0){strcpy(str,str1);strcat(str,str2);}

elseif(strcmp(str1,str2)<0){strcpy(str,str2);strcat(str,str1);}elsestrcpy(str,str1);len3=strlen(str);puts(str);printf(”Len1=%d,Len2=%d,Len3=%d\n”,len1,len2,len3);}例strcmp與strlen舉例Howareyou?Hello!Len1=6,Len2=12,Len3=18應(yīng)用舉例例輸入一行字符,統(tǒng)計其中有多少個單詞輸入一字符串給stringi=0num=0word=0當(dāng)((c=string[i])!=‘\0’)c=空格真真假假word=0word=1num=num+1i=i+1輸出:numword==0#include<stdio.h>main(){charstring[81];inti,num=0,word=0;charc;

gets(string);

for(i=0;(c=string[i])!='\0';i++)

if(c=='')word=0;

elseif(word==0){word=1;num++;}printf("Thereare%dwords\intheline\n",num);}當(dāng)前字符=空格是否未出現(xiàn)新單詞,使word=0,num不累加前一字符為空格(word==0),新單詞出現(xiàn),word=1,num加1前一字符為非空格(word==1),未出現(xiàn)新單詞,num不變否0是11是1未01否0是12否1未12是1未02否0是13是1未03否0是14否1未14否1未14否1未14例輸入:Iamaboy.

當(dāng)前字符是否空格word原值新單詞開始否word新值num值

Iamaboy.例有三個字符串,找出其中最大者

How\0

Hello\0

High\0

str[0]str[1]str[2]#include<stdio.h>#include<string.h>main(){charstring[20],str[3][20];inti;

for(i=0;i<3;i++)gets(str[i]);

if(strcmp(str[0],str[1])>0) strcpy(string,str[0]);elsestrcpy(string,str[1]);if(strcmp(str[2],string)>0) strcpy(string,str[2]);printf("\nThelargeststring\is:\n%s\n",string);}例有十個學(xué)生的成績,求平均分9285687554889845617992856854889845756179a[0]a[1]a[2]a[3]a[4]a[5]a[6]a[7]a[8]a[9]a#include<stdio.h>main(){intk,a[10];for(k=0;k<10;k++)scanf(“%d”,&a[k]);for(k=0;k<10;k++)sum+=a[k];printf(“Averageis%d\n”,sum/10);}例有三個學(xué)生四門課成績92856875

54889845

61798140張三李四王二數(shù)學(xué)化學(xué)英語物理二維數(shù)組例比較inta[2][3]={{5,6},{7,8}};

與inta[2][3]={5,6,7,8};560780567800例inta[][10];floatf[2][]={1.2,2.2};例inta[5];a={2,4,6,8,10};例inta[10];fl

溫馨提示

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

評論

0/150

提交評論