第11章--指针与数组

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
C程序设计
void sort(int x[ ],int n) { int i,j,k,t; for(i=0;i<n-1;i++){ k=i; for(j=i+1;j<n;j++) if(x[j]>x[k]) k=j; if(k!=i) { t=x[i]; x[I]=x[k]; x[k]=t; } }
(4)*(p+i)或*(a+i)是p+i或a+i所指向的数组元素,即a
[i]。 (5) 如果指针变量p1和p2都指向同一数组,如执行p2-p1,结果是两个地址
之差除以数组元素的长度。
C程序设计
11.1.3 通过指针引用数组元素
引用一个数组元素,可以用: (1) 下标法,如a[i]形式; (2) 指针法,如*(a+i)或*(p+i)。其中a是 数组名,p是指向数组元素的指针变量,其初值p=a。
也就是使p指向a数组的第0号元素 。
C程序设计
C程序设计
11.1.2 指针的运算
C言规定在指针指向数组元素时,可以对指针进行以下运 算:
加一个整数(用+或+=),如p+1
减一个整数(用-或-=),如p-1 自加运算,如p++,++p 自减运算,如p--,--p 两个指针相减,如p1-p2 (只有p1和p2都指向同一
C程序设计
void inv(int *x,int n) /*形参x为指针变量*/ {int p,temp,*i,*j; i=x;j=x+n-1; for(;i<j;i++,j--) {temp=*i;*i=*j;*j=temp;} return; }
C程序设计
如果有一个实参数组,想在函数中改变此数组中的 元素的值,实参与形参的对应关系有以下4种情况 :
C程序设计
表 示 形 式
含义
地 址
a
a[0], *(a+0), *a a+1,&a[1]
二维数组名,指向一维数组 a[0],即0行首地址 0行0列元素地址
2000
2000
1行首地址
2008 2008 2012
a[1],*(a+1) 1行0列元素a[1][0]的地址 a[1]+2, *(a+1)+2, &a[1][2] *(a[1]+2), *(*(a+1)+2), a[1][2] 1行2列元素a[1][2] 的地址
例11.1
输出数组中的全部元素
假设有一个a数组,整型,有10个元素。要输出各元素的 值有三种方法:
C程序设计
(1)下标法 #include <stdio.h> void main() { int a[10]; int i; for(i=0;i<10;i++) scanf(“%d”,&a[i]); for(i=0;i<10;i++) printf(“%d ”,a[i]); putchar(‘\n’); }
(1) 形参和实参都用数组名,如: void main() { int a[10]; … f(a,10); } void { } f(int x[ ],int n)

C程序设计
C程序设计
(2) 实参用数组名,形参用指针变量。如: void main() void f(int *x,int n) {int a[10]; { … … f(a,10); } }
。指针变量既然可以指向变量,当然也可以指向数组元
素(把某一元素的地址放到一个指针变量中)。所谓数 组元素的指针就是数组元素的地址。
C程序设计
可以用一个指针变量指向一个数组元素。
例如:int
a[10]; (定义a为包含10个整型数据的数 组)
int
*p; (定义p为指向整型变量的指针变量)
p=&a[0]; (把a[0]元素的地址赋给指针变量p)
C程序设计
11.2 指针和二维数组间的关系
用指针变量可以指向一维数组中的元素,也可以指向多维 数组中的元素。但在概念上和使用上,多维数组的指针比一维 数组的指针要复杂一些。 1. 多维数组元素的地址 先回顾一下多维数组的性质,可以认为二维数组是“数组的数 组”,例 : 定义int a[3][4]={{1,3,5,7},{9,11,13 ,15},{17,19,21,23}}; 则二维数组a是由3个一维数组所组成的。设二维数组的首行的 首地址为2000 ,则
3,7,9,11,0,6,7,5,4,2 The array has been inverted: 2,4,5,7,6,0,11,9,7,3 C程序设计
C程序设计
对刚才的程序可以作一些改动。将函数inv中的 形参x改成指针变量。
#include <iostream.h> void main() {void inv(int *x,int n); int i,a[10]={3,7,9,11,0,6,7,5 ,4,2}; printf(″The original array:\n″); for(i=0;i<10;i++) printf(“%d “,a[i]); putchar(‘\n’); inv(a,10); printf(“The array has been in verted:\n″); for(i=0;i<10;i++) printf(“%d “,a[i]); putchar(‘\n’); }
第11章 指针和数组
C程序设计
本章主要内容

11.1 指针和一维数组间的关系
11.2 指针和二维数组间的关系
11.3 返回指针值的函数


11.4 指针数组和多重指针
11.5 动态分配内存空间
C程序设计
11.1 指针与一维数组间的关系
11.1.1 数组元素的指针
一个变量有地址,一个数组包含若干元素,每个数 组元素都在内存中占用存储单元,它们都有相应的地址
C程序设计
void inv(int *x,int n) {int p,m,temp,*i,*j; i=x;j=x+n-1; for(;i<j;i++,j--) {temp=*i;*i=*j;*j=temp;} return; }
C程序设计
例11.5 用选择法对10个整数按由大到小顺序排序
#include <stdio.h> void main() { void sort(int x[],int n); int *p,i,a[10]; p=a; for(i=0;i<10;i++) scanf(“%d”,&a[i]); p=a; sort(p,10); for(p=a,i=0;i<10;i++) { printf(“%d “,*p); p++; } }
数组中的元素时才有意义)。
C程序设计
分别说明如下:
(1)如果指针变量p已指向数组中的一个元素,则p+1指向同一数组中的下
一个元素,p-1指向同一数组中的上一个元素。 (2) 如果p原来指向a[0],执行++p后p的值改变了,在p的原值基础上加d
,这样p就指向数组的下一个元素a[1]。
(3) 如果p的初值为&a[0],则p+i和a+i就是数组元素a[i]的 地址,或者说,它们指向a数组的第i个元素 。
1行2列元素a[1][2]的值
元素值为13
C程序设计
2 . 指向多维数组元素的指针变量 (1) 指向数组元素的指针变量
例11.6 用指向元素的指针变量输出二维数组元素的值
运行结果如下: 1 3 5 7 9 11 13 15 19 21 23
#include <iostream.h> void main() { int a[3][4]={ 1,3,5,7,9,11,13,15,17,19,21,23}; int *p; for(p=a[0];p<a[0]+12;p++) {if((p-a[0])%4==0) putchar(‘\n’); printf(“%d ”,*p); } }
程序运行情况: 1 2 3 4 5 6 7 8 9 0↙ 1 2 3 4 5 6 7 8 9 0 C程序设计
11.1.4
用数组名作函数参数
在第8章中介绍过可以用数组名作函数的参数。 如: void main() { void f(int arr[],int n); int array[10]; ┇ f(array,10); ┇ } void f(int arr[],int n) { ┇ }
(3)实参形参都用指针变量。例如: void main() {int a[10], *p=a; ┇ f(p,10); }
void f(int *x,int n) { ┇ }
C程序设计
C程序设计
(4) 实参为指针变量,形参为数组名。如:
void main() {int a[10],*p=a; ┇ ┇ f(p,10); } void f(int x[ ],int n) {
}
C程序设计
例11.4用实参指针变量改写例11பைடு நூலகம்3。
#include <stdio.h> void main() { void inv(int *x,int n); int i,arr[10],*p=arr; printf(″The original array:\n″); for(i=0;i<10;i++,p++) scanf(“%d “,p); p=arr; inv(p,10); /* 实参为指针变量 */ printf(″The array has been inverted : \n″); for(p=arr;p<arr+10;p++) printf(“%d “,*p); putchar(‘\n’); }
C程序设计
(3) 用指针变量指向数组元素。 #include <stdio.h> void main() { int a[10]; int *p,i; for(i=0;i<10;i++) scanf(“%d”,&a[i]); for(p=a;p<(a+10);p++) printf(“%d ”,*p); putchar(‘\n’); }
C程序设计
void inv(int x[ ],int n) /*形参x是数 组名*/ { int temp,i,j; for(i=0,j=n-1;i<j;i++,j--) { temp=x[i]; x[i]=x[j]; x[j]=temp; } 运行情况如下: return ; The original array: }
C程序设计
(2) 通过数组名计算数组元素地址,找出元素的值。 #include <stdio.h> void main() { int a[10]; int i; for(i=0;i<10;i++) scanf(“%d”,&a[i]); for(i=0;i<10;i++) printf(“%d “,*(a+i)); putchar(‘\n’); }
1 2 3 4 5 6 7 8 9 0↙
22153 234 0 0 30036 25202 11631 8259 8237 28483
显然输出的数值并不是a数组中各元素的值 C程序设计
#include <stdio.h> void main() { int *p,i,a[10]; p=a; for(i=0;i<10;i++) scanf(“%d”,p++); p=a; for(i=0;i<10;i++,p++ ) printf(“%d “,*p); }
C程序设计
例11.3 将数组a中n个整数按相反顺序存放
C程序设计
#include <stdio.h> void main() { void inv(int x[],int n); int i,a[10]={3,7,9,11,0,6,7,5 ,4,2}; printf(“The original array:\n”); for(i=0;i<10;i++) printf(“%d “,a[i]); putchar(‘\n’); inv(a,10); printf(″The array has been in verted:\n″); for(i=0;i<10;i++) printf(“%d “,a[i]); putchar(‘\n’); }
C程序设计
例11.2 通过指针变量输出a数组的10个元素。
#include <stdio.h> void main() { int *p,i,a[10]; p=a; for(i=0;i<10;i++ ) scanf(“%d”,p++); for(i=0;i<10;i++,p++ ) printf(“%d “,*p); 程序运行情况: }
相关文档
最新文档