数组与指针优秀课件

合集下载

专题7 数组和指针的应用

专题7  数组和指针的应用

例1. 写出结果: main() { int *p1, a[10]={1,2,3,4,5,6,7,8,9,10} ; p1=a; printf(“%d ”,*p1); printf(“%d ”,*p1++); printf(“%d ”, *(p1+3)); printf(“%d ”,*++p1); printf(“%d ”,(*p1)++); printf(“%d ”,*p1--); printf(“%d ”,*p1); } 例2.若有定义语句:double x[5]={1.0,2.0,3.0,4.0,5.0},*p=x;则错误引用x数 组元素的是[08年9月] A)*p B)x[5] C)*(p+1) D)*x
[C] D) aa+1
(3)通过指针变量来表示数组中各元素的地址
可以定义一个指针变量来存放数组的指针或数组元素的指针,且指针变 量的基类型就是定义数组时的类型 int *p,a[10]; for(p=a,k=0; k<10;k++) p++; 将数据写入数组元素中几种方式: (1)for(p=a,k=0; k<10;k++) { scanf(“%d”,p); p++; } 进一步简化: (2)for(p=a,k=0; k<10;k++) scanf(“%d”,p++); 再进一步简化: (3)for(p=a,p-a<10; p++) scanf(“%d”,p); 以上三种写法是等价的,要掌握,能看懂。
2、 通过指针变量来引用一维数组元素 当指针变量指向数组中的某个数组元素时,可以通过“*”来访问其所 指向变量的数据。

C语言指针PPT

C语言指针PPT

8.1.2 指针变量的定义与初始化(续)
2.指针变量的初始化 指针变量初始化的一般形式为: 存储类型说明 数据类型 *指针变量名=初始地址值; 说明: (1)赋值号前面的部分为指针的定义,在定义的同时立刻赋值。 (2)初始地址值通常为如下形式:int x,*px=&x; (3)初始地址值最好不要为具体的十六进制的整数,因为不知该地址是否 可用。
8.1.3 指针的引用及运算
1.指针的引用 在引用指针变量时,可能有3种情况: (1)给指针变量赋值。如: pa=&a; 即把a的地址赋给指针变量pa,又称pa指向a。 (2)引用指针变量指向的变量。 如果已执行“pa=&a;”,即指针变量pa指向了整型变量a,则: printf("%d",*p); 其作用是以整数形式输出指针变量p所指向的变量的值,即变量a的值。
【导入案例:函数中多数据的返回】
定义学生信息管理系统中的某个子模块的功 能,实现从键盘输入一个班级中所有学生的某 门课程的成绩,通过调用函数实现统计,按规 定格式输出最高分、最低分、平均分,同时输 出优秀人数、良好人数、及格人数、不及格人 数以及所占比例。
分析
在前面我们所讲的函数中,只能有一个返 回值பைடு நூலகம்参数之间只能是实参的值传递给形参, 实现的是单向传递。程序中要求返回最高分、 最低分、平均分以及各分数段的人数及所占 比例等多个返回值。如何使函数能有多个返 回值呢?这就需要用到指针。
利用存储空间的地址,可以访问存储空间,从而获得存储空间
的内容。地址就好像是一个路标,指向存储空间。因此,又把地址
形象地称为指针。
8.1.1指针的概念(续)
1.地址及取地址运算符
地址 0012FF56H

数组与指针

数组与指针

此外,还可通过算术元运算对指针进行移动, 此外,还可通过算术元运算对指针进行移动,来达到引用 其他数组元素的目的。 其他数组元素的目的。 a[0] p p &a[0] *p a[0] a[1] p+1 p+1 &a[1] *(p+1) a[1] a[2] P+2 p+2 &a[2] *(p+2) a[2] a[3] P+3 p+3 &a[3] *(p+3) a[3] a[4] p+4 p+4 &a[4] *(p+4) a[4]
a[0] a[1] a[2] a[3] a[4]
a
a a+1 a+2 a+3 a+4
a a+1 a+2 a+3 a+4
&a[0] &a[1] &a[2] &a[3] &a[4]
*a *(a+1) *(a+2) *(a+3) *(a+4)
a[0] a[1] a[2] a[3] a[4]
例3: main() { int a[5],*p,i; for(i=0;i<5;i++) scanf(“%d”,a+i); for(i=0;i<5;i++) printf(“%d”,*(a+i)); }
a[1] a[1][0] a[1][1] a[1][2]
此处, 的值与 的值与a[0]的值相同,但是基类型不同。a是二级 的值相同, 此处,a的值与 的值相同 但是基类型不同。 是二级 指针, 是一级指针。 指针,a[0]是一级指针。 是一级指针 a &a[0][0] a[0] 因此,以下赋值语句是错误的: 因此,以下赋值语句是错误的:p=a; a &a[0] a+1 &a[1] a+i &a[i] *(a+i) a[i]

C语言程序设计课件 .ppt

C语言程序设计课件 .ppt

定义C为字符数组,包含10个元素。在赋值以后数组的状态 如图所示: c[0] c[1] c[2] c[3] c[4] c[5] c[6] c[7] c[8] c[9]
I
am
happ y
2020/4/12
24
2、字符数组的初始化
与一般数组的初始化方法类似。
例如char c[ ]={‘I’,’ ’,’a’,’m’,’ ’,’a’,’ ’,’s’,’t’,’u’,’d’,’e’, ’n’,’t’}
a[0] ---------------------- a 00 a 01 a 02 a 03
a
a[1] ---------------------- a 10
a 11
a 12
a 13
a[2] ---------------------- a 20 a 21 a 22 a 23
上面定义的二维数组可以理解为定义了3个一维数组,即 相当于 float a[0][4],a[1][4],a[2][4]
85 555 58 444 44 822 22 280 00 008
第第 第 第结 一二三 四 次次 次 次果
2020/4/12
11
根据流程图写出程序(今设n=10),定义数组长度为11, 本例中对a[0]不用,只用 a[1]到a[10],以符合人们的习惯。
流程图如下:
输入n个数给a[1]到a[n] for j=1 to n-1
for (i=1;i<=10-j;i++) if (a[i]>a[i+1]) {t=a[i];a[i]=a[i+1];a[i+1]=t;}
printf(“the sorted numbers :\n”); for (i=1;i<11;i++)

指针与数组

指针与数组

3.通过一个行指针变量引用二维数组的元素
定义一个由m个元素组成的一维数组的指 针变量的一般形式:
类型标识符 (*指针变量名)[m];
注意:*p两侧的圆括号不可缺少。 例如:假若有语句 int a[2][3], (*p)[3]; p=a;
则:⑴ p是一个指向由3个整型元素组成的一 维数 组的指针变量。
方法ain() { int a[10]={54,65,8,2,3,56,8,21,57,98},i;
for(printf("\n"),i=0;i<10;i++) printf("%4d",*(a+i)); }
方法三:用指针变量指向数组元素
main() { int a[10]={54,65,8,2,3,56,8,21,57,98},*p,i;
⑵ p指向a数组,p+1指向数组a的下一行首地 址,a和p的基类型相同,则a数组中任意元 素a[i][j]还可以如下表示: *(p[i]+j) 、*(*(p+i)+j) 、(*(p+i))[j] 、p[i][j]
例:使用行指针变量访问数组元素。
main() {
float fa[5][10], (*pf)[10]=fa; int i,j; for(i=0; i<5; i++)
C语言程序设计
指针与数组
1.1 一维数组的指针
数组的指针 :是数组的起始地址。
数组元素的指针 :是数组元素的地址。 当指针变量指向数组或数组元素时,它就是指 向数组的指针变量。
C规定: ⑴数组名代表数组的首地址(起始地址),
也就是第一个元素的地址。
⑵当指针变量p指向数组时,p+1指向数组 的下一个元素。假设一个整型元素占两 个字节,p+1是使p的地址加2个字节。

数组和指针

数组和指针

● 数组:数组是具有一定顺序关系的若干对象的集合体,组成数组的对象称为该数组的元素。

▲ 每个元素有n个下标的数组称为n维数组。

▲ a[100]:下标从0开始,到99止,不能为100。

▲ a[i][j]:i为行标,j为下标。

● 数组的声明:数组类型数组名[表达式1][表达式2]……● 数组的使用:数组类型数组名[表达式1][表达式2]……● 数组的存储:数组元素在内存中是顺序、连续存储的。

● 数组的初始化:就是在声明数组时给部分或全部元素赋初值。

▲ int a[3]={1,2,3}; 等价于 int[]{1,2,3};▲ int a[5]={1,2,3}; //部分初始化,必须连续,不能间隔赋初值▲ int a[2][3]={1,2,3,4,5,6}; 等价于 int a[][3]={1,2,3,4,5,6} //给出全部的初值时,行标可省▲ int a[2][3]={{1,2},{3,4},{5,6}};● 数组作为函数参数▲ 使用数组名传递数据时,传递的是地址▲ 使用数组名做函数的参数,则实参和形参都应该是数组名,且类型要相同▲ 对形参数组的修改,也就是对实参数组的修改▲ int ss(int a[][4],int bb) 调用:ss(b,x); //b是数组,x传递的是第一维的维数● 对象数组▲ 声明:类名数组名[下标表达式]▲ 引用:数组名[下标].成员名▲ 当一个数组中的元素对象被删除时,系统会调用析构函数来完成扫尾工作。

● 指针:是对地址直接操作的手段。

动态内存分配和管理也离不开指针● 指针类型:用来存放内存单元地址的变量类型,就是指针类型。

● 指针变量的声明:数据类型 *标识符;● 与地址相关的运算——"*"和"&"▲ "*"称为指针运算符(也称解析(dereference)),表示获取指针所指向的变量的值,是一元操作符。

指针与数组

指针与数组

#include <stdio.h>
int main()
{ int a[6],i,s,*p;
printf("Please input data:\n");
for(i=0; i<6; i++ )
scanf("%d", &a[i] );
s=0;
for(p=a; p<a+6; p++) s+=*p ;
printf(“s=%d\n”,s);
8
指针与数组
❖指针运算:
指针类型的数据,除了间接引运算、赋值运算 p 2000
等操作外,当指针指向数组时,指针可以做
加减整数、指针相减及指针比较运算。
▪ 1.指针与整数的加、减运算
• 如果指针p是指向数组中的某个元素,加
p+3 2012
上整数n后,新指针p+n指向后续的第n个
a数组
1 2 3 4 5
a[0] a[1] a[2] a[3]
a[4]
元素。
a[5]
▪ 2.指针相减运算
a[6]
• 两个指向同个数组的同类型指针作相减运
a[7]
算,其绝对值表示它们之间相隔的元素数 目。
p+92036
a[8] a[9]
▪ 3.指针之间作关系运算
• 两个相同类型指针可作关系运算比较指针
大小。例8.5程序循环控制是通过 p<a+6
– 行指针a+2,转化为元素指针*(a+2),指向第3行第一个元素,即 a[2][0]。
– 行指针a+i,转化为元素指针*(a+i)+j,指向第i+1行第j+1一个元素, 即a[i][j]。

第5章 数组与指针

第5章 数组与指针

也可以用函数strcpy( )实现:
char amounts[6]=”hello”; char customer[6]; strcpy(customer, amounts); /*可以将amounts中的数据复制给 customer*/
(3)strcat()——字符串的连接 该函数是将一个字符串连接到另一个字符串的后面 ,得到一个新的字符串。如要将字符串customer连接到 字符串amounts的后面,可以采用下列语句:
float temp; for(int i=0;i<29;i++) { for(int j=i+1;j<30;j++) { if (cj[i]<cj[j]) { temp = cj[i]; cj[i] = cj[j]; cj[j] = temp; } } } }
//排序
void display( ) { for(int j = 0;j< 30; ++j) { cout << cj[j]<< endl; } } }; int main( ) { students C1; C1.sortData( ); C1.display( ); }
例如:要记录学生的姓名,该如何定义数组?
分析:由于学生的姓名是属于字符串,所以要定义一个字符串数组,如 果每个学生的姓名长度在20个字符以内,则可以定义该数组的长度为21 。
char name[21];
• 5.1.4字符串的主要操作
1.字符串的输入和输出 字符串的输入和输出与一般变量的输入与输出类似, 用cin和cout实现。
第5章 数组与指针
本章学习要点
• 1. 掌握一维数组的定义、赋初值以及简单应用; • 2. 掌握一维字符数组和字符串之间的关系,了解字符 串的常用操作; • 3. 掌握二维数组的定义、赋初值,了解其应用; • 4. 掌握指针的定义和运算; • 5. 掌握指针与一维数组、字符串的关系; • 6. 掌握动态内存管理的方法; • 7.掌握别名引用和指针引用。
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
……}; 当提供了数组中所有结构值时,不必用这种括号的形式。 keyword keytab[]={"auto", 0,"break", 0,"case", 0,"char", 0,
……"unsigned", 0,"volatile", 0,"while", 0,};
2020/11/13
计算机基础教研室
长度 必须是正整型常数或整型常量表达式
只有一个 [长度] 的数组为一维数组,有两个 [长度] 的 数组为二维数组,……,有n个 [长度] 的数组为n维数组。
存储类别可以是auto、static、extern,缺省时为auto
2020/11/13
计算机基础教研室
5
例如:
int a[10]; float b[3][4]; int c[10],d[10][20],e[3][4][5];
2020/11/13
计算机基础教研室
3
数组的概念
数组的引入:
数组(array)是一种顺序容器(sequence container),是
由单一类型元素组成的一个有序集合:
int fibon[10]={0,1,1,2,3,5,8,13,21,34};
a a1,a2,a3,…………,an
下标变量名
i
脚标(下标)
8
数组与数组元素及其存储方式
数组元素的访问方式:
通过下标操作符(subscript),按元素 在数组中的位置进行访问,称为索引访 问(indexing)或下标访问 (subscripting)。参见图5.1 。
fibon[0] 0 fibon[1] 1 fibon[2] 2 fibon[3] 3
fibon[8] 21 fibon[9] 34
存储单元占用内存大小相同,各元素的存储单元之间没有空隙, 可以从数组第一个元素存储单元的起始地址计算出任意一个元 素存储单元的起始地址。
2020/11/13
计算机基础教研室
10
【例 5.1】找最大数和最小数
const int SIZE=15; int main(){
int arr[SIZE], i,high,low; for (i=0;i<SIZE;i++) arr[i]=rand()%100; cout << "Here are the " <<SIZE
struct keyword { char word[16]; //关键字 int count; //该关键字将在源程序中出现的次数 };
初始化:
结构数组初始化时可以用括号来区分每一个结构,例如: keyword keytab[]={{"auto", 0},{"break", 0},{"case", 0},
<<" random numbers :"<<endl; for (i=0;i<SIZE;i++) cout<<arr[i]<<'\t'; cout<<endl; high=arr[0]; //初始化时最大和最小值均为数组首元素 low=arr[0]; for(i=1;i<SIZE;i++){if(arr[i]>high) high=arr[i];
数组与指针优秀课件
本章重点
本章将深入学习数组包括多维数组的知识和 应用,以及它们与指针的关系。
C++语言拥有在运行时获得变量地址和操纵地 址的能力,这种可用来操纵地址的变量类型就是 指针。指针可以用于数组,用于内存访问,还可 作为函数的参数。
2020/11/13
计算机基础教研室
2
数组
5.1.1 数组、数组元素及其存储方式 5.1.2 数组名作为函数参数

则:a数组的下标在0~9之间
B数组的第一维(行)下标在0~2之间,第二维(列)下标在 0~3之间
其他以次类推。
2020/11/13
计算机基础教研室
6
数组元素的引用 数组名[ 下标 ]【 [ 下标 ] 】……
~ 下标 必须介于 0 长度-1 之间,可以是整型表达式
如:a[3] b[2][2]
一个数组元素等价于一个简单变量
int a[5]={1,2,3};
int b[3][4]={1,2,3,4,5,6,7,8,9,10,11,12};
int b[][4]={1,2,3,4,5,6,7,8,9,10,11,12};
int b[3][4]={{1,2,3,4},{5,6,7,8},{9,10,11,12}};
in2t02b0/1[13/1]3[4]={{1,2,3},计{5算,6机},基{9础,10教,1研1室,12}};
2020/11/13
计算机基础教研室
7
数组元素的初始化 在定义数组的同时赋以初始值称为初始化
【 存储类别 】 元素类型 数组名[【长度】]【 [ 长度 ]】……={ 初始数据表 };
此时第一维的长度可以省略,但[ ]不能省! 初始数据表可以是:数据【,数据】……
还可以适当加{ } 如:int a[5]={1,2,3,4,5};
if(arr[i]<low) low=arr[i]; } cout<<"highest value is "<<high<<endl; cout<<"lowest value is "<<low<<endl; return 0;}
2020/11/13
计算机基础教研室
11
数组与数组元素及其存储方式
结构数组定义:
12
数组与数组元素及其存储方式
对象数组定义:
CGoods goods[3]; 该商品类对象数组包含3个商品对象数组元素,系统调用3次默认的
下标变量
下标变量名相同、下标个数也相同、类型也相同的一组下
标变量的集合称为数组。含有一个下标的数组为一维数组,含 有两个下标的数组为二维数组,…………
2020/11/13
计算机基础教研室
4
数值型数组
数组的定义
【 存储类别 】 元素类型 数组名[ 长度 ]【 [ 长度 ] 】……;
【 】表示【 】中的内容可省略 【 】…… 表示【 】中的内容可重复0~n次
图5.1 数组在内存中的存储
2020/11/13
计算机基础教研室
9
数组与数组元素及其存储方式
注意: 1: 数组是一种组合类型,是不能作为一个整体进行访问和
处理的,只能按元素进行个别的访问和处理。 2: C++数组第一个元素的下标为0,而不是1,且下标表
达方式是固定的。 3:数组元素在内存中是从低地址开始顺序排列,各元素的
相关文档
最新文档