| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 254 人关注过本帖
标题:关于调用语句的不解
只看楼主 加入收藏
meishanhuang
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2012-2-12
结帖率:81.82%
收藏
已结贴  问题点数:5 回复次数:1 
关于调用语句的不解
现有以下程序
void f30(int x[ ],int y[ ],int n,int m)
 { int i,count=0;
   for (i=0;i<n;i++)
      if(x[i]>m)
        y[++count]=x[i];
   y[0]=count;
}
 main( )
 { int a[10]={156,12,89,44,38,45,31,27,55,72},b[11];
   f30(a,b,10,50);
   for(int i=1;i<b[0];i++)
      printf("%d\t",b[i]);
   printf("%d\n",b[b[0]]);
}
该程序大概意思是在数组a中寻找比50大的数并输出,但具体语句我有点看不懂请指教,特别是红字部分,谢谢
搜索更多相关主题的帖子: void count 
2013-03-07 00:29
Susake
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:女儿国的隔壁
等 级:贵宾
威 望:23
帖 子:2288
专家分:6481
注 册:2012-12-14
收藏
得分:5 
程序代码:
#include <stdio.h>

void f(int x[], int y[], int n, int m) {
    int i, count = 0;
    for(i = 0; i < n; i++)
        if(x[i] > m) y[++count] = x[i];
    y[0] = count;
}

int main() {
    int a[10] = {156, 12, 89, 44, 38, 45, 31, 27, 55, 72}, b[11], i;
    f(a, b, 10, 50);
    for(i = 1; i < b[0]; i++)
        printf("%-4d", b[i]);
    printf("%d\n", b[b[0]]);
    return 0;
}
看了你的代码,我心碎了一地,首先没有头文件....好吧,开始分析了
1.任何代码都是从main()开始的所以我们先从主函数开始吧
程序代码:
int main() {
    int a[10] = {156, 12, 89, 44, 38, 45, 31, 27, 55, 72}, b[11], i;
    ......
    .....
    return 0;
}
这个就不解释了,数组的初始化和定义一个数组b,和变量i......你看看你的是什么,我不知道是谁教你那么写的
2.接着到了函数调用f(a, b, 10, 50);   里面是实参等下要进行参数的传递的....截下来看到调用的函数
程序代码:
void f(int x[], int y[], int n, int m) {
    int i, count = 0;
    for(i = 0; i < n; i++)
        if(x[i] > m) y[++count] = x[i];
    y[0] = count;
}

传递的参数是a,b数组和10(n),50(m)两个常量
用一个for循环将a数组的每个数与50做比较,如果>50,将值赋给数组b,让count的最终结果赋给y[0]即b[0]
3.最后看输出
for(i = 1; i < b[0]; i++)
        printf("%-4d", b[i]);
    printf("%d\n", b[b[0]]);

用for循环将b数组中已经放入的大于50的数输出,这里的b[0]即count,最后的b[b[0]]即b[count],相当于将上面的for(i = 1; i <= b[0]; i++)中i=b[0]的情况
搞定睡觉!



仰望星空...........不忘初心!
2013-03-07 01:10
快速回复:关于调用语句的不解
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.024845 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved