上一题下一题
跳转到
 
 
  世界如此多姿,发展如此迅速,窥一斑未必还能知全豹。但正如万花筒一样,每一个管窥都色彩斑斓。  
 
 
  知识通道 | 学习首页 | 教师首页 | PK首页 | 知识创造首页 | 企业首页 | 登录
 
本文对应知识领域
数组名作函数参数
作者:未知 申领版权
2012年01月24日 共有 1552 次访问 【添加到收藏夹】 【我要附加题目
受欢迎度:

    

数组名作函数参数

数组名可以作函数的实参和形参。如:
    
    main()
    {int array[10];
    ……
    ……
    f(array,10);
    ……
    ……
    }
    
    f(int arr[],int n);
    {
    ……
    ……
    }
    array为实参数组名,arr为形参数组名。在学习指针变量之后就更容易理解这个问题了。数组名就是数组的首地址,实参向形参传送数组名实际上就是传送数组的地址,形参得到该地址后也指向同一数组。这就好象同一件物品有两个彼此不同的名称一样。
    
    同样,指针变量的值也是地址,数组指针变量的值即为数组的首地址,当然也可作为函数的参数使用。
    【例10.15】
    float aver(float *pa);
    main(){
    float sco[5],av,*sp;
    int i;
    sp=sco;
    printf("\ninput 5 scores:\n");
    for(i=0;i<5;i ) scanf("%f",&sco[i]);
    av=aver(sp);
    printf("average score is %5.2f",av);
    }
    float aver(float *pa)
    {
    int i;
    float av,s=0;
    for(i=0;i<5;i ) s=s *pa ;
    av=s/5;
    return av;
    }
    
    【例10.16】将数组a中的n个整数按相反顺序存放。
    算法为:将a[0]与a[n-1]对换,再a[1]与a[n-2] 对换……,直到将a[(n-1/2)]与a[n-int((n-1)/2)]对换。今用循环处理此问题,设两个“位置指示变量”i和j,i的初值为0,j的初值为n-1。将a[i]与a[j]交换,然后使i的值加1,j的值减1,再将a[i]与a[j]交换,直到i=(n-1)/2为止,如图所示。
    
    程序如下:
    void inv(int x[],int n)   /*形参x是数组名*/
    {
    int temp,i,j,m=(n-1)/2;
    for(i=0;i<=m;i )
    {j=n-1-i;
    temp=x[i];x[i]=x[j];x[j]=temp;}
    return;
    }
    main()
    {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]);
    printf("\n");
    inv(a,10);
    printf("The array has benn inverted:\n");
    for(i=0;i<10;i )
    printf("%d,",a[i]);
    printf("\n");
    }
    
    对此程序可以作一些改动。将函数inv中的形参x改成指针变量。
    【例10.17】对例10.16可以作一些改动。将函数inv中的形参x改成指针变量。
    程序如下:
    void inv(int *x,int n)   /*形参x为指针变量*/
    {
    int *p,temp,*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;}
    return;
    }
    main()
    {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]);
    printf("\n");
    inv(a,10);
    printf("The array has benn inverted:\n");
    for(i=0;i<10;i )
    printf("%d,",a[i]);
    printf("\n");
    }
    
    运行情况与前一程序相同。
    【例10.18】从0个数中找出其中最大值和最小值。
    调用一个函数只能得到一个返回值,今用全局变量在函数之间“传递”数据。程序如下:
    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;p<array_end;p )
    if(*p>max)max=*p;
    else if (*p<min)min=*p;
    return;
    }
    main()
    {int i,number[10];
    printf("enter 10 integer umbers:\n");
    for(i=0;i<10;i )
    scanf("%d",&number[i]);
    max_min_value(number,10);
    printf("\nmax=%d,min=%d\n",max,min);
    }
    
    说明:
    1) 在函数max_min_value中求出的最大值和最小值放在max和min中。由于它们是全局,因此在主函数中可以直接使用。
    2) 函数max_min_value中的语句:
    max=min=*array;
    array是数组名,它接收从实参传来的数组numuber的首地址。
    *array相当于*(&array[0])。上述语句与 max=min=array[0];等价。
    3) 在执行for循环时,p的初值为array 1,也就是使p指向array[1]。以后每次执行p ,使p指向下一个元素。每次将*p和max与min比较。将大者放入max,小者放min。
    
    4) 函数max_min_value的形参array可以改为指针变量类型。实参也可以不用数组名,而用指针变量传递地址。
    【例10.19】程序可改为:
    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;p<array_end;p )
    if(*p>max)max=*p;
    else if (*p<min)min=*p;
    return;
    }
    main()
    {int i,number[10],*p;
    p=number;             /*使p指向number数组*/
    printf("enter 10 integer umbers:\n");
    for(i=0;i<10;i ,p )
    scanf("%d",p);
    p=number;
    max_min_value(p,10);
    printf("\nmax=%d,min=%d\n",max,min);
    }
    

 

相关新闻

保护模式
地址表达式
存储器分段和地址的形成
堆栈段的说明
联合类型的定义
结构和联合和枚举
数组元素的指针
结构指针变量作函数参数
使用字符串指针变量与字符数组的区别

您可能对这些感兴趣  

第7讲 综合分析BIM在运用与推广中的障碍问题
考核学生质量的困难
日本福岛核电站事故初步分析
论科技异化与科技人化
中国科技计划项目管理现状与对策
财政科技资金的审计重点和内容
软科学研究机构在政府决策中的功效、困境及对策研究
打造超级DOS系统(下)
DOS命令基础应用(6)
打造超级DOS系统(上)

题目筛选器
日期:
类型:
状态:
得分: <=
分类:
作者:
职业:
关键字:
搜索

 
 
 
  焦点事件
 
  知识体系
 
  职业列表
 
 
  最热文章
 
 
  最多引用文章
 
 
  最新文章
 
 
 
 
网站介绍 | 广告服务 | 招聘信息 | 保护隐私权 | 免责条款 | 法律顾问 | 意见反馈
版权所有 不得转载
沪ICP备 10203777 号 联系电话:021-54428255
  帮助提示    
《我的太学》是一种全新的应用,您在操作中遇到疑问或者问题,请拨打电话13564659895,15921448526。
《我的太学》