[物理]指针.ppt

  1. 1、本文档共45页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[物理]指针

例题2、从键盘输入一个班学生的一门课的成绩(每班人数最多不超过40人,具体人数由键盘输入),试用函数编程实现打印最高分及其学号。 #includestdio.h #define ARR_SIZE 40 void FindMax(float score[],long num,int n,float *pMaxScore,long *pMaxNum); void main() { float score[ARR_SIZE],maxScore;//数组score存储所有学生成绩 //maxScore存储最高成绩 int n,i; long num[ARR_SIZE],maxNum;//数组num存储所有学生的学号 //maxNum存储最高成绩学生的学号 printf(请输入学生人数:); scanf(%d,n); printf(请输入学生的学号和成绩:\n); for(i=0;in;i++) { scanf(%ld%f,num[i], score[i]); } FindMax(score,num,n,maxScore,maxNum); printf(maxScore = %.0f,maxNum =%ld\n,maxScore,maxNum); } void FindMax(float score[ ],long num[ ],int n, float *pMaxScore, long *pMaxNum) { int i; int a[ARR_SIZE]; *pMaxScore = score[0]; *pMaxNum = num[0]; for(i=1; in; i++) { if(score[i]*pMaxScore) { *pMaxScore=score[i]; *pMaxNum = num[i]; } } } 五、字符指针作为函数参数 一、字符指针 1、概念:指向字符型数据的指针变量 2、字符指针变量的定义: char *ptr; 3、字符指针的初始化 char *ptr = “abcd”; 4、字符指针的赋值; 5、以字符指针指向的地址为起点输入字符串; 字符指针作为函数参数 二、字符指针做函数参数 例题:从键盘输入一个字符串a,将字符串a复制到字符数组b中,并输出字符串b。 字符指针作为函数参数 字符指针作为函数参数 #includestdio.h void MyStrcpy(char *dstStr,const char *srcStr); main(){ char a[80],b[80]; printf(请输入一个字符串:); gets(a); MyStrcpy(b,a); printf(结果:); puts(b); } 数组名或指针变量作函数参数 例题:(插入排序)在一个已排好序(由小到大)的数组中查找待插入数据x应插入的位置,使其插入后,数组元素扔保持由小到大的顺序。 数组名或指针变量作函数参数 数组名或指针变量作函数参数 数组名或指针变量作函数参数 #includestdio.h #define ARR_SIZE 10 void Insert(int *a,int n,int x); main() { int a[ARR_SIZE+1],x,i,n; printf(请输入数组中已有的元素的个数:); scanf(%d,n); printf(请输入插入前已排好序的数组元素:); for(i=0;in;i++) { scanf(%d,a[i]); } printf(请输入要插入的元素x:); scanf(%d,x); Insert(a,n,x); printf(插入%d后的数组为:\n,x); for(i=0;in+1;i++) { printf(%-4d,a[i]); } printf(\n); } 数组名或指针变量作函数参数 void Insert(int *a,int n,int x) { int i,pos; for(i=0;inx*(a+i);i++) ; pos=i; for(i=n-1;i=pos;i--) { *(a+i+1)=*(a+i); } *(a+pos)=x; } 课后练习 一、预习思考

文档评论(0)

qiwqpu54 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档