A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© wehuazi 中级黑马   /  2014-10-16 20:40  /  1096 人查看  /  6 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文


  1. // 设计一个函数,找出整型数组元素的最小值
  2. #include <stdio.h>
  3. //声明函数min()
  4. int min();
  5. int main()
  6. {
  7.     //1.定义一个数组,并赋初值
  8.     int a[] = {3,2,1,4,5,-1,0};
  9.     //2.调用min函数,并输出结果
  10.     printf("%d\n",min(a));
  11. }

  12. int min(int array[])
  13. {
  14.     //定义最小值m为数组的第一个
  15.     int m = array[0];
  16.     //以数组长度遍历数组
  17.     for(int i=1; i<=<span style="line-height: 2.2em;">sizeof(</span><span style="line-height: 2.2em;">array</span><span style="line-height: 2.2em;">)/sizeof(int)</span><span style="line-height: 2.2em;">; i++)</span>
复制代码
为什么sizeof(array)/sizeof(int)  处飘黄,改为sizeof((int)array)/sizeof(int) 后不飘黄,但是值又不是需要的了.在main函数中值正常,而且不会飘黄.求大神的解决.




评分

参与人数 1技术分 +1 收起 理由
星河鹭起 + 1

查看全部评分

6 个回复

倒序浏览
你确定结果正常??把所有代码都发出来看看
回复 使用道具 举报
明天过后1 发表于 2014-10-16 21:25
你确定结果正常??把所有代码都发出来看看


  1. #include <stdio.h>
  2. //声明函数min()
  3. int min();
  4. int main()
  5. {
  6.     //1.定义一个数组,并赋初值
  7.     int a[] = {3,2,1,4,5,-1,0};
  8.     int l = sizeof(a)/sizeof(int);
  9.     //2.调用min函数,并输出结果
  10.     printf("%d\n",min(a,l));
  11. }

  12. int min(int array[],int l)
  13. {
  14.     //定义最小值m为数组的第一个
  15.     int m = array[0];
  16.     //以数组长度遍历数组
  17.     for(int i=1; i<=l; i++)
  18.         //如果有比m小的,将较小值赋值给m
  19.         if(m>array[i])
  20.             m = array[i];
  21.     //返回最小值
  22.     return m;
  23. }
复制代码
回复 使用道具 举报

结果正常,基础测试满分,就是写的时候飘黄,才改成现在这样的.
回复 使用道具 举报
1. 数组作为函数的参数来接收传进来的数组的时候,为了效率问题,形参的数组当指针用,该形参数组指向源数组的首地址
2. 如果你在函数中这样写   sizeof(array) 相当于求指针 array变量 的内存大小哦,
3. 由于main函数中的数组已经分配好内存空间(在main函数的栈内存中分配), a就代表这这个数组空间的首地址
4. sizeof 求变量的内存空间,首先会得到该变量的首地址,然后根据变量的类型(变量类型是告诉如何寻址)来计算所占有内存空间大小(寻址好像你跨一步要走多远的距离,差不多这意思吧)

点评

讲解的真好,加油!  发表于 2014-10-16 21:49
回复 使用道具 举报 1 0
把之前有问题的代码一块发出来才有对比性啊。
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马