第08章指針_第1頁
第08章指針_第2頁
第08章指針_第3頁
第08章指針_第4頁
第08章指針_第5頁
已閱讀5頁,還剩87頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、鄭州電子信息職業(yè)技術學院信息管理系鄭州電子信息職業(yè)技術學院信息管理系C語言程序設計課件語言程序設計課件 C語言程序設計課題組語言程序設計課題組 二二0一一0年七月年七月第八章 指針C程序設計中使用指針可以:l使程序簡潔、緊湊、高效l有效地表示復雜的數(shù)據(jù)結構l動態(tài)分配內存l得到多于一個的函數(shù)返回值地址和指針的概念程序中: int i; float k; 內存中每個字節(jié)有一個編號-地址.2000200120022005內存02003ik 編譯時為其分配內存單元 將變量名轉換為變量的地址變量是對程序中數(shù)據(jù)存儲空間的抽象直接訪問與間接訪問v直接訪問:按變量地址存取變量值v間接訪問:通過存放變量地址的變

2、量去訪問變量例 i=3; -直接訪問.2000200420062005整型變量i10變量i_pointer20012002200320003例 *i_pointer=20; -間接訪問20i2000332000i2000i_pointer33地址指向變量的單元C中將地址形象化的稱為“指針”變量的地址稱為變量的指針.2000200420062005整型變量i10變量i_pointer200120022003指針與指針變量v指針:一個變量的地址v指針變量:專門存放變量地址的變量叫2000指針指針變量 變量的內容 變量的地址指針變量變量變量地址(指針)變量值指向地址存入指針變量指針變量.200020

3、0420062005整型變量i10變量i_pointer2001200220032000整型變量k例 k=i; -直接訪問 k=*i_pointer; -間接訪問10例 k=i; k=*i_pointer; 變量的指針和指向變量的指針變量指針變量的定義v一般形式: 數(shù)據(jù)類型 *指針變量名;3變量i2000i_pointer*i_pointeri*i_pointer&ii_pointeri=3;*i_pointer=3合法標識符指針可以指向的數(shù)據(jù)類型表示定義指針變量不是*運算符例 int *p1,*p2; float *q ; char *name;注意:1、int *p1, *p2;

4、與 int *p1, p2;2、指針變量名是p1,p2 ,不是*p1,*p23、定義指針變量時必須指定基類型4、指針變量只能指向定義時所規(guī)定類型的變量5、指針變量定義后,變量值不確定,應用前必須先賦值int *p1;float f=3.5;p1=&f;printf(“%d”,*p1);例 main( ) int i=10; int *p; *p=i; printf(“%d”,*p); 危險!例 main( ) int i=10,k; int *p; p=&k; *p=i; printf(“%d”,*p); 指針變量必須先賦值,再使用.2000200420062005整型變量i1

5、0指針變量p200120022003隨機 &與*運算符含義: 取變量的地址單目運算符優(yōu)先級: 2結合性:自右向左含義: 取指針所指向變量的內容單目運算符優(yōu)先級: 2結合性:自右向左v兩者關系:互為逆運算v理解.2000200420062005整型變量i10變量i_pointer2001200220032000指針變量i_pointer-指針變量,它的內容是地址量*i_pointer-指針的目標變量,它的內容是數(shù)據(jù)&i_pointer-指針變量占用內存的地址200010i_pointer*i_pointer&i_pointerii_pointer = &ii =

6、*i_pointer例 通過指針變量訪問整型變量main() int a,b; int *p1,*p2; a=100;b=10; p1=&a; p2=&b; printf(%d,%dn,a,b); printf(*%d,%dn,*p1,*p2);運行結果:100,10100,10.f86f8af8cf8b整型變量a10指針變量p1f87f88f89f86說明l程序中兩處出現(xiàn)的*p1,*p2的區(qū)別l地址賦值語句p1=&a;不能寫成*p1=&al(*p1)+的含義是什么 *(p1+)的含義是什么例 輸入兩個數(shù),并使其從大到小輸出main() int *p1,*p2,

7、*p,a,b; scanf(%d,%d,&a,&b); p1=&a; p2=&b; if(ab) p=p1; p1=p2; p2=p; printf(a=%d,b=%dn,a,b); printf(max=%d,min=%dn,*p1,*p2);運行結果:a=5,b=9 max=9,min=5.指針變量p1 指針變量p20002008200220042006 指針變量p2 整型變量b 整型變量a5200692008200620082006指針變量作為函數(shù)參數(shù)地址傳遞swap(int x,int y) int temp; temp=x; x=y; y=temp;m

8、ain() int a,b; scanf(%d,%d,&a,&b); if(ab) swap(a,b); printf(n%d,%dn,a,b);例_1 將數(shù)從大到小輸出.20002008200A2002200420065變量a 變量b(main)9 變量temp 變量y 變量x(swap)559 59COPY指針變量作為函數(shù)參數(shù)地址傳遞swap(int x,int y) int temp; temp=x; x=y; y=temp;main() int a,b; scanf(%d,%d,&a,&b); if(ab) swap(a,b); printf(n%d,%

9、dn,a,b);例 將數(shù)從大到小輸出值傳遞.20002008200A2002200420065變量a 變量b(main)9運行結果:5, 9swap(int *p1, int *p2) int p; p=*p1; *p1=*p2; *p2=p;main() int a,b; int *pointer_1,*pointer_2; scanf(%d,%d,&a,&b); pointer_1=&a; pointer_2=&b; if(ab)swap(pointer_1,pointer_2); printf(n%d,%dn,a,b);.20002008200A20022

10、0042006200C200E2010.59整型變量a 整型變量b(main)指針pointer_1指針pointer_220002002(swap)指針p1指針p2整型p5920002002COPY5例 將數(shù)從大到小輸出swap(int *p1, int *p2) int p; p=*p1; *p1=*p2; *p2=p;main() int a,b; int *pointer_1,*pointer_2; scanf(%d,%d,&a,&b); pointer_1=&a; pointer_2=&b; if(ab)swap(pointer_1,pointer_2

11、); printf(n%d,%dn,a,b);.20002008200A200220042006200C200E2010.59整型變量a 整型變量b(main)指針pointer_1指針pointer_22000200259例 將數(shù)從大到小輸出運行結果:9,5地址傳遞swap(int *p1, int *p2) int *p; *p=*p1; *p1=*p2; *p2=*p;main() int a,b; int *pointer_1,*pointer_2; scanf(%d,%d,&a,&b); pointer_1=&a; pointer_2=&b; if(a

12、b) swap(pointer_1,pointer_2); printf(n%d,%dn,a,b);運行結果:9,9int x;int *p=&x;x;例 將數(shù)從大到小輸出.20002008200A200220042006200C200E2010.59整型變量a 整型變量b(main)指針pointer_1指針pointer_2200020029920002002COPY(swap)指針p1指針p2指針p*假設2000指針變量在使用前必須賦值!swap(int x,int y) int t; t=x; x=y; y=t;main() int a,b; int *pointer_1,*p

13、ointer_2; scanf(%d,%d,&a,&b); pointer_1=&a; pointer_2=&b; if(ab) swap(*pointer_1,*pointer_2); printf(n%d,%dn,a,b);運行結果:5,9例 將數(shù)從大到小輸出值傳遞.20002008200A200220042006200C200E2010.59整型a 整型b(main)pointer_1pointer_2200020029COPY(swap)整型x整型y整型t555 9運行結果:5,9例 將數(shù)從大到小輸出swap(int *p1, int *p2) int

14、*p; p=p1; p1=p2; p2=p;main() int a,b; int *pointer_1,*pointer_2; scanf(%d,%d,&a,&b); pointer_1=&a; pointer_2=&b; if(ab) swap(pointer_1,pointer_2); printf(%d,%d,*pointer_1,*pointer_2);.20002008200A200220042006200C200E2010.59整型a 整型b(main)pointer_1pointer_22000200220002002COPY(swap)指針p1

15、指針p2指針p*2000地址傳遞20002002說明 如想通過函數(shù)調用得到n個要改變的值l在主調函數(shù)中設n個變量,用n個指針變量指向它們l用指針變量作實參,將n個變量的地址傳給索調用的函數(shù)的形參l通過形參指針變量,改變該n個變量的值l主調函數(shù)中可以使用這些改變了值的變量注意:不能企圖通過改變指針形參的值而使指針實參的值改變swap(int *pt1, int *pt2) int temp; temp=*pt1; *pt1=*pt2; *pt2=temp;exchange(int *q1,int *q2,int *q3) if(*q1*q2) swap(q1,q2); if(*q1*q3) sw

16、ap(q1,q3); if(*q2*q3) swap(q2,q3);例 輸入a、b、c3個數(shù),按大小順序輸出main() int a,b,c,*p1,*p2,*p3; scanf(%d,%d,%d,&a,&b,&c); p1=&a; p2=&b;p3=&c; exchange(p1,p2,p3); printf(n%d,%d,%dn,a,b,c);數(shù)組的指針與指向數(shù)組的指針變量指向數(shù)組元素的指針變量例 int array10; int *p; p=&array0; / p=array;或 int *p=&array0;或 int

17、*p=array;array0array1array2array3array9.整型指針p&array0p數(shù)組名是表示數(shù)組首地址的地址常量通過指針引用數(shù)組元素lC規(guī)定:若P為指向數(shù)組元素的指針變量,則P+1指向同一數(shù)組的下一個元素lP+1 P+1*d (d為p指向的變量所占字節(jié)數(shù))如果p的初值為&a0,則:lp+i和a+i就是ai的地址, a+i計算方法同p+il*( p+i )或*( a+i )就是ai 為變址運算符,將ai按*( a+i )計算地址,然后找出此地址單元中的內容l指向數(shù)組的指針變量也可以帶下標,如pi與 *( p+i )等價數(shù)組元素表示方法a0a1a2a3a9

18、.aa+9a+1a+2地址元素下標法a0a1a2a9a0a1a2a3a9.pp+9p+1p+2地址元素指針法*p*(p+1)*(p+2)*(p+9) 變址運算符ai *(a+i)ai pi *(p+i) *(a+i)*a*(a+1)*(a+2)*(a+9)p0p1p2p9例 輸出數(shù)組中的全部元素main() int a10,i; for(i=0;i10;i+) scanf(%d,&ai); for(i=0;i10;i+) printf(%5d,ai); printf(n);main() int a10,i; for(i=0;i10;i+) scanf(%d,&ai); for(

19、i=0;i10;i+) printf(%5d,*(a+i); printf(n);main() int a10,i,*p; for(i=0;i10;i+) scanf(%d,&ai); for(p=a;pa+10;p+) printf(%5d,*p); printf(n); 注意:1、指針變量可以實現(xiàn)使本身的值改變。如p+ 而a+能否實現(xiàn)呢?2、要注意指針變量的當前值例 通過指針變量輸出數(shù)組中的元素main() int a10,i,*p; p=a; for(i=0;i10;i+) scanf(%d,p+); for(i=0;i10;i+,p+) printf(%5d,*p); prin

20、tf(n);pp58762730123456apppppp指針變量可以指到數(shù)組后的內存單元例 通過指針變量輸出數(shù)組中的元素main() int a10,i,*p; p=a; for(i=0;i10;i+) scanf(%d,p+); p=a; for(i=0;i10;i+,p+) printf(%5d,*p); printf(n); 3、要注意指針變量的運算 P+,使P指向下一元素 *P+等價于*(P+) *(P+)與*(+P)的作用不同 (*P)+的含義 如果P當前指向數(shù)組a中的第i個元素,則: *(P-)相當于ai- *(+P)相當于a+i *(-P)相當于a-i例 int a=1,2,3

21、,4,5,6,7,8,9,10,*p=a,i; 數(shù)組元素地址的正確表示:(A)&(a+1) (B)a+ (C)&p (D)&pi數(shù)組名作函數(shù)參數(shù)v數(shù)組名作函數(shù)參數(shù),是地址傳遞v形參是用來接收從實參傳遞過來的數(shù)組首地址的。因此,形參應該是一個指針變量(只有指針變量才能存放地址)。實際上,C編譯都是將形參數(shù)組作為指針變量來處理的。vf(int arr ,int n)等價于 f(int *arr,int n)v數(shù)組名作函數(shù)參數(shù),實參與形參的對應關系v為了便于理解,我們可以用數(shù)組名作形參v實參數(shù)組代表一個固定的地址,是指針常量 形參數(shù)組并不是一個固定的地址例 將數(shù)組a中的n個整

22、數(shù)按相反順序存放 ij 3 7 9 11 0 6 7 5 4 20 1 2 3 4 5 6 7 8 9ijijijji11760594723實參與形參均用數(shù)組void inv(int x, int n) int temp,i,j,m=(n-1)/2; for(i=0;i=m;i+) j=n-1-i; temp=xi; xi=xj; xj=temp; main() int i,a10=3,7,9,11,0,6,7,5,4,2; printf(The original array :n); for(i=0;i10;i+) printf(%d,ai); printf(n); inv(a,10); p

23、rintf(The array has been reverted:n); for(i=0;i10;i+) printf(%d,ai); printf(n);m=4例 將數(shù)組a中的n個整數(shù)按相反順序存放 void inv(int *x, int n) int temp,*p,*i,*j,m=(n-1)/2; i=x; j=x+n-1; p=x+m; for(;i=p;i+,j-) temp=*i; *i=*j; *j=temp; main() int i,a10=3,7,9,11,0,6,7,5,4,2; printf(The original array :n); for(i=0;i10;i

24、+) printf(%d,ai); printf(n); inv(a,10); printf(The array has been reverted:n); for(i=0;i10;i+) printf(%d,ai); printf(n);實參用數(shù)組,形參用指針變量37911067542a0a1a2a3a4a5a6a7a8a9xp=x+ma數(shù)組60711594723ijijijjiji例 從10個數(shù)中找出其中最大值和最小值 int max,min;void max_min_value(int array, int n) int *p,*array_end;array_end=array+n;

25、max=min=*array; for(p=array+1;pmax) max=*p; else if(*pmin) min=*p; return;main() int i,number10; for(i=0;i10;i+) scanf(%d,&numberi); max_min_value(number,10); printf(max=%d,min=%dn,max,min);實參用數(shù)組,形參用指針變量arrayP(開始)array,number數(shù)組array_end37911067542array0array1array2array3array4array5array6array7a

26、rray8array9例 從10個數(shù)中找出其中最大值和最小值 int max,min;void max_min_value(int *array, int n) int *p,*array_end;array_end=array+n; max=min=*array; for(p=array+1;pmax) max=*p; else if(*pmin) min=*p; return;main() int i,number10,*p=number; for(i=0;i10;i+,p+) scanf(%d,p); p=number; max_min_value(p,10); printf(max=%

27、d,min=%dn,max,min);實參與形參均用指針變量一個實參數(shù)組,想在函數(shù)中改變此數(shù)組的元素的值,實參與形參的表示形式有以下幾種情況: l形參和實參都用數(shù)組名l實參用數(shù)組名,形參用指針變量l實參形參都用指針變量l實參為指針變量,形參為數(shù)組名例 將實參改為指針變量 void inv(int *x, int n) int temp,*p,*i,*j,m=(n-1)/2; i=x; j=x+n-1; p=x+m; for(;i=p;i+,j-) temp=*i; *i=*j; *j=temp; main() int i,arr10,*p=arr; for(i=0;i10;i+,p+) sca

28、nf(%d,p); p=arr; inv(p,10); printf(The array has been reverted:n); for(p=arr;parr+10;p+) printf(%d ,*p);實參用指針變量沒有會怎樣?例 將實參改為指針變量 void inv(int *x, int n) int temp,*p,*i,*j,m=(n-1)/2; i=x; j=x+n-1; p=x+m; for(;i=p;i+,j-) temp=*i; *i=*j; *j=temp; main() int i,*arr; for(i=0;i10;i+) scanf(%d,arr+i); inv(

29、arr,10); printf(The array has been reverted:n); for(i=0;i10;i+) printf(%d ,*(arr+i);只定義指針變量指針變量作實參必須有確定值!例 用選擇法對10個整數(shù)排序 main( ) int i,a10,*p=a; for(i=0;i10;i+) scanf(%d,p+); p=a; sort(p,10); for(p=a,i=0;i10;i+) printf(%d ,*p);p+形參用數(shù)組sort(int x, int n) int t,i,j,k; for(i=0;in-1;i+) k=i; for(j=i+1;jxk

30、) k=j; if(k!=i) t=xi; xi=xk; xk=t; 例 用選擇法對10個整數(shù)排序 main( ) int i,a10,*p=a; for(i=0;i10;i+) scanf(%d,p+); p=a; sort(p,10); for(p=a,i=0;i10;i+) printf(%d ,*p);p+形參用指針變量sort(int *x, int n) int t,i,j,k; for(i=0;in-1;i+) k=i; for(j=i+1;j*(x+k) k=j; if(k!=i) t=*(x+i); *(x+i)=*(x+k); *(x+k)=t; 指針變量與數(shù)組的關系int

31、 *p 與 int q10 l數(shù)組名是指針(地址)常量lp=q; p+i 是qi的地址l數(shù)組元素的表示方法:下標法和指針法, 即若p=q, 則 pi qi *(p+i) *(q+i) l形參數(shù)組實質上是指針變量,即int q int *ql在定義指針變量(不是形參)時,不能把int *p 寫成int p;指向多維數(shù)組的指針和指針變量多維數(shù)組的地址對于一維數(shù)組:(1)數(shù)組名array表示數(shù)組的首地址,即array0的地址;(2)數(shù)組名array是地址常量(3)array+i是元素arrayi的地址(4)arrayi *(array+i)arrayint array10;對于二維數(shù)組:(1)a是數(shù)

32、組名, 包含三個元素 a0,a1,a2(2)每個元素ai 又是一個一維 數(shù)組,包含4個 元素,ai為 數(shù)組名aa+1a+2int a34;a0a1a2200020082016200020022008201020162018a00a01a10a11a20a21a02a03a12a13a22a23a0+1a1+1a2+1*(a+0)+1*(a+1)+1*(a+2)+1*(*(a+0)+1)*(a0+1)l對二維數(shù)組 int a34,有ua-二維數(shù)組的首地址,即第0行的首地址ua+i-第i行的首地址uai *(a+i)-第i行第0列的元素地址uai+j *(a+i)+j -第i行第j列的元素地址u*

33、(ai+j) *(*(a+i)+j) aijla+i=&ai=ai=*(a+i) =&ai0, 值相等,含義不同ua+i &ai,表示第i行首地址,指向行uai *(a+i) &ai0,表示第i行第0列元素地址,指向列int a34;a0a1a2200020082016200020022008201020162018a00a01a10a11a20a21a02a03a12a13a22a23aa+1a+2int a34;a00a01a10a11a20a21a02a03a12a13a22a23二維數(shù)組元素表示形式:(1)a12(2)*(a1+2)(3)*(*(a+1)

34、+2)(4)*(&a00+1*4+2)地址表示:(1) a+1 (2) &a10(3) a1(4) *(a+1)行指針列指針地址表示:(1) &a12(2) a1+2(3) *(a+1)+2(4)&a00+1*4+2表示形式含義地址a二維數(shù)組名,數(shù)組首地址a0,*(a+0),*a第0行第0列元素地址a+1第1行首地址a1,*(a+1)第1行第0列元素地址a1+2,*(a+1)+2,&a12第1行第2列元素地址*(a1+2),*(*(a+1)+2),a12第1行第2列元素值2000200020082008201213注意:在行指針的前面加一個*就轉換成列指

35、針,在列指針的前面加一個&就轉換成行指針。例 輸出二維數(shù)組的相關值#define FORMAT “%d,%dn”main() int a34=1,3,5,7,9,11,13,15,17,19,21,23; printf(FORMAT,a,*a); printf(FORMAT,a0,*(a+0); printf(FORMAT,&a0,&a00); printf(FORMAT,a1,a+1); printf(FORMAT,&a10,*(a+1)+0); printf(FORMAT,a2,*(a+2); printf(FORMAT,&a2,a+2); prin

36、tf(FORMAT,a10,*(*(a+1)+0);運行結果:-66,-66-66,-66-66,-66-58,-58-58,-58-50,-50-50,-509,9v指向多維數(shù)組的指針變量l指向二維數(shù)組元素的指針變量例 用指針變量輸出數(shù)組元素的值main() int a34=1,3,5,7,9,11,13,15,17,19,21,23; int *p; for(p=a0;pa0+12;p+) if(p-a0)%4=0) printf(n);printf(%4d ,*p); p=*a; p=&a00; p=*(a+0); p=a; int a34;a00a01a10a11a20a21a

37、02a03a12a13a22a23p例 用指針變量輸出數(shù)組元素的值main() int a34=1,3,5,7,9,11,13,15,17,19,21,23; int *p; for(p=a0;pa0+12;p+) if(p-a0)%4=0) printf(n);printf(“%o,%4d ”,p,*p); 如果要輸出指定的元素,可先計算出該元素的相對位置計算數(shù)組元素aij在數(shù)組中的相對位置的計算公式: i*m+j(m為二維數(shù)組的列數(shù))例 輸出二維數(shù)組任一行任一列元素的值main() int a34=1,3,5,7,9,11,13,15,17,19,21,23; int i,j,(*p)4;

38、 p=a; scanf(“%d,%d ,&i,&j); printf(“a%d,%d=%dn“,i,j,*(*(p+i)+j);int a34;a00a01a10a11a20a21a02a03a12a13a22a23ppp 指向一維數(shù)組的指針變量定義形式:數(shù)據(jù)類型 (*指針名)一維數(shù)組維數(shù); 例 int (*p)4; 說明:u int (*p)4;定義一個指向一味數(shù)組的指針變量pu int (*p)4與int *p4不同u p的值是一維數(shù)組的首地址,p是行指針u*p則是列指針u*p則是元素的值p13571357p+1*p例 二維數(shù)組與指針運算main() int a34=1,2

39、,3,4,3,4,5,6,5,6,7,8; int i; int (*p)4=a,*q=a0; for(i=0;i3;i+) if(i=0) (*p)i+i/2=*q+1;else p+,+q; for(i=0;i3;i+) printf(%d,aii); printf(%d,%dn,*(*p),*q);運行結果:2,4,7,5,3123434565678pq2pqpq 多維數(shù)組的指針作函數(shù)參數(shù)l用指向變量的指針變量l用指向一維數(shù)組的指針變量l用二維數(shù)組名實參形參數(shù)組名int x4指針變量int (*q)4數(shù)組名int x4指針變量int (*q)4數(shù)組名a數(shù)組名a指針變量p1指針變量p1若i

40、nt a34; int (*p1)4=a; int *p2=a0;指針變量p2指針變量int *q例 3個學生各學4門課,計算總平均分,并輸出第n個學生成績main() void average(float *p,int n); void search(float (*p)4,int n); float score34=65,67,79,60,80,87,90,81,90,99,100,98; average(*score,12); search(score,2);void average(float *p,int n) float *p_end, sum=0,aver; p_end=p+n-

41、1; for(;p=p_end;p+)sum=sum+(*p); aver=sum/n; printf(average=%5.2fn,aver);void search(float (*p)4, int n) int i; printf( No.%d :n,n); for(i=0;i4;i+) printf(%5.2f ,*(*(p+n)+i);列指針行指針函數(shù)說明float p46552796080879081909910098pp pni例例 3個學生各學個學生各學4門課,計算總平均分,并查找一門以門課,計算總平均分,并查找一門以 上課不及格學生,上課不及格學生, 輸出其各門課輸出其各門課

42、成績成績void search(float (*p)4, int n) int i,j,flag; for(j=0;jn;j+) flag=0;for(i=0;i4;i+) if(*(*(p+j)+i)60) flag=1;if(flag=1) printf(No.%d is fail,his scores are:n,j+1); for(i=0;iy) z=x; else z=y; return(z);main() int max(int ,int), (*p)(); int a,b,c; p=max; scanf(%d,%d,&a,&b); c=(*p)(a,b); pri

43、ntf(a=%d,b=%d,max=%dn,a,b,c);int max(int x,int y) int z; if(xy) z=x; else z=y; return(z);用函數(shù)指針變量作函數(shù)參數(shù)例用函數(shù)指針變量作參數(shù),求最大值、最小值和兩數(shù)之和main() int a,b,max(int,int), min(int,int),add(int,int); void process(int,int,int (*fun)(); scanf(%d,%d,&a,&b); process(a,b,max); process(a,b,min); process(a,b,add);vo

44、id process(int x,int y,int (*fun)() int result; result=(*fun)(x,y); printf(%dn,result);max(int x,int y) min(int x,int y) add(int x,int y) 返回指針值的函數(shù) 函數(shù)定義形式: 類型標識符 *函數(shù)名(參數(shù)表);例 int *f(int x, int y)例 指針函數(shù)實現(xiàn):有若干學生成績,要求輸入學生序號后, 能輸出其全部成績main() float score4=60,70,80,90, 56,89,67,88,34,78,90,66; float *search

45、(float (*pointer)4,int n); float * p;int i,m; printf(Enter the number of student:); scanf(%d,&m); printf(The scores of No.%d are:n,m); p=search(score,m); for(i=0;i*y)return x; elsereturn y;main() int a=2,b=3; int *p; p=f1(&a, &b); printf(%dn,*p);.20002008200A20022004200623 指針變量y 指針變量x(f1

46、)20022000COPY變量a 變量b(main) 指針變量p*例 寫一個函數(shù),求兩個int型變量中居于較大值的變量的地址.20002008200A2002200420062變量a 變量b(main)3 指針變量p*2002int *f1(int *x,int *y) if(*x*y)return x; elsereturn y;main() int a=2,b=3; int *p; p=f1(&a,&b); printf(%dn,*p);例 寫一個函數(shù),求兩個int型變量中居于較大值的變量的地址int *f3(int x,int y) if(xy)return &x

47、; elsereturn &y;main() int a=2,b=3; int *p; p=f3(a, b); printf(%dn,*p);.20002008200A20022004200623 變量y 變量x(f3)32COPY變量a 變量b(main) 指針變量p*例 寫一個函數(shù),求兩個int型變量中居于較大值的變量的地址不能返回形參或局部變量的地址作函數(shù)返回值.20002008200A2002200420062變量a 變量b(main)3 指針變量p*200Aint *f3(int x,int y) if(xy)return &x; elsereturn &y;

48、main() int a=2,b=3; int *p; p=f3(a,b); printf(%dn,*p); 指針數(shù)組和指向指針的指針用于處理二維數(shù)組或多個字符串指針數(shù)組v定義:數(shù)組中的元素為指針變量v定義形式:數(shù)據(jù)類型 *數(shù)組名數(shù)組長度說明;例 int *p4;指針所指向變量的數(shù)據(jù)類型區(qū)分int *p4與int (*p)4v指針數(shù)組賦值與初始化賦值:main() int b23,*pb2; pb0=b0; pb1=b1; .int *pb2pb0pb1int b23123246初始化:main() int b23,*pb =b0,b1; .int *pb2pb0pb1int b2312324

49、6v指針數(shù)組賦值與初始化L i s p 0F o r t r a n 0B a s i c 0p0p1p2p30賦值:main() char a=Fortran; char b=Lisp; char c=Basic; char *p4; p0=a; p1=b; p2=c; p3=NULL; .或:main() char *p4; p0= Fortran; p1= Lisp; p2= Basic; p3=NULL; .初始化:main() char *p=Fortran, Lisp, Basic,NULL; .L i s p 0F o r t r a n 0B a s i c 0p0p1p2p3

50、0 char name59=“gain”,“much”,“stronger”, “point”,“bye”; char *name5=“gain”,“much”,“stronger”, “point”,“bye”;g a i n 0s t r o n g e r 0p o i n t 0m u c h 0name0name1name2name3name4b y e 0g a i n 0s t r o n g e r 0p o i n t 0m u c h 0b y e 0 二維數(shù)組與指針數(shù)組區(qū)別:二維數(shù)組存儲空間固定字符指針數(shù)組相當于可變列長的二維數(shù)組指針數(shù)組元素的作用相當于二維數(shù)組的行名但指

51、針數(shù)組中元素是指針變量二維數(shù)組的行名是地址常量main() int b23,*pb2; int i,j; for(i=0;i2;i+) for(j=0;j3;j+) bij=(i+1)*(j+1); pb0=b0; pb1=b1; for(i=0;i2;i+) for(j=0;j3;j+,pbi+) printf(b%d%d:%2dn,i,j,*pbi);例 用指針數(shù)組處理二維數(shù)組int *pb2pb0pb1int b23b00 *pb0b01 *(pb0+1)b02 *(pb0+2)b10 *pb1b11 *(pb1+1)b12 *(pb1+2)123246例 對字符串排序main() vo

52、id sort(char *name,int n), print(char *name,int n); char *name=Follow me,BASIC, Great Wall,FORTRAN,Computer ; int n=5; sort(name,n); print(name,n);void sort(char *name,int n) char *temp; int i,j,k; for(i=0;in-1;i+) k=i; for(j=i+1;j0) k=j; if(k!=i) temp=namei; namei=namek; namek=temp; name0name1name2

53、name3name4nameGreat WallFORTRANComputerFollow meBASICkjkjjji=0void print(char *name,int n) int i; for(i=0;in;i+) printf(“%sn”,namei); 例 對字符串排序main() void sort(char *name,int n), print(char *name,int n); char *name=Follow me,BASIC, Great Wall,FORTRAN,Computer ; int n=5; sort(name,n); print(name,n);vo

54、id sort(char *name,int n) char *temp; int i,j,k; for(i=0;in-1;i+) k=i; for(j=i+1;j0) k=j; if(k!=i) temp=namei; namei=namek; namek=temp; name0name1name2name3name4nameGreat WallFORTRANComputerFollow meBASICkkjjji=1k例 對字符串排序main() void sort(char *name,int n), print(char *name,int n); char *name=Follow

55、me,BASIC, Great Wall,FORTRAN,Computer ; int n=5; sort(name,n); print(name,n);void sort(char *name,int n) char *temp; int i,j,k; for(i=0;in-1;i+) k=i; for(j=i+1;j0) k=j; if(k!=i) temp=namei; namei=namek; namek=temp; name0name1name2name3name4nameGreat WallFORTRANComputerFollow meBASICkkjji=2例 對字符串排序ma

56、in() void sort(char *name,int n), print(char *name,int n); char *name=Follow me,BASIC, Great Wall,FORTRAN,Computer ; int n=5; sort(name,n); print(name,n);void sort(char *name,int n) char *temp; int i,j,k; for(i=0;in-1;i+) k=i; for(j=i+1;j0) k=j; if(k!=i) temp=namei; namei=namek; namek=temp; name0nam

57、e1name2name3name4nameGreat WallFORTRANComputerFollow meBASICkkji=3例 對字符串排序main() void sort(char *name,int n), print(char *name,int n); char *name=Follow me,BASIC, Great Wall,FORTRAN,Computer ; int n=5; sort(name,n); print(name,n);void sort(char *name,int n) char *temp; int i,j,k; for(i=0;in-1;i+) k=

58、i; for(j=i+1;j0) k=j; if(k!=i) temp=namei; namei=namek; namek=temp; name0name1name2name3name4nameGreat WallFORTRANComputerFollow meBASIC 指向指針的指針v一級指針:指針變量中存放目標變量的地址p1&p2&i3P2(指針變量)i(整型變量)例 int *p1; int *p2; int i=3; p2=&i; p1=&p2; *p1=5;v二級指針:指針變量中存放一級指針變量的地址例 int *p; int i=3; p=&

59、;i; *p=5;&i3P(指針變量)i(整型變量)一級指針單級間接尋址二級指針一級指針目標變量二級間接尋址l定義形式:數(shù)據(jù)類型 *指針名;如 char *p;例 int i, *p; p=&i; ()/p是二級指針,不能用變量地址為其賦值最終目標變量的數(shù)據(jù)類型*p是p間接指向對象的地址*p是p間接指向對象的值例 int i=3; int *p1; int *p2; p1=&i; p2=&p1; *p=5;ip1p23&i&p1*p2, *p1*p2v多級指針例 三級指針 int *p; 四級指針 char *p;20002008200A2002

60、2004200612變量a 變量b(main) 指針變量p2000 指針變量q2002例 一級指針與二級指針#include void swap(int *r,int *s) int *t; t=r; r=s; s=t;main() int a=1,b=2,*p,*q; p=&a; q=&b; swap(p,q); printf(%d,%dn,*p,*q);20022000COPY 指針變量s 指針變量r(swap) 指針變量t20002002200020002008200A20022004200612變量a 變量b(main) 指針變量p2000 指針變量q2002例 一級指

61、針與二級指針#include void swap(int *r,int *s) int *t; t=r; r=s; s=t;main() int a=1,b=2,*p,*q; p=&a; q=&b; swap(p,q); printf(%d,%dn,*p,*q);輸出: 1,2例 一級指針與二級指針#include void swap(int *r,int *s) int *t; t=r; r=s; s=t;main() int a=1,b=2,*p,*q; p=&a; q=&b; swap(p,q); printf(%d,%dn,*p,*q);abpqabpqrsabpqsrabpq輸出: 1,2例 一級指針與二級指針#include void swap(int *r,int *s) int *t; t=*r; *r=*s; *s=t;main() int a=1,b=2,*p,*q; p=

溫馨提示

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

評論

0/150

提交評論