鱼C论坛

 找回密码
 立即注册
查看: 1556|回复: 3

[已解决]自定义函数问题

[复制链接]
发表于 2019-5-21 20:26:08 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. /*用冒泡法对20个随机元素的数组排序*/
  2. #include <stdio.h>
  3. #include <time.h>
  4. #include <stdlib.h>
  5. void mppx(int a[])
  6. {
  7.     int i, j, t, s;
  8.     s = sizeof(a) / sizeof(a[0]);
  9.     for (i = 0; i < s; i++)
  10.     {
  11.         for (j = 0; j < (s - 1); j++)
  12.         {
  13.             if (a[j] >= a[j + 1])
  14.             {
  15.                 t = a[j];
  16.                 a[j] = a[j + 1];
  17.                 a[j + 1] = t;
  18.             }
  19.         }
  20.     }
  21.     for (i = 0; i < s; i++)
  22.     {
  23.         printf("a[%d] = %d\n", i, a[i]);
  24.     }
  25. }
  26. void main()
  27. {
  28.     int b[19], i;
  29.     srand(time(NULL));
  30.     printf("排序之前\n");
  31.     for (i = 0; i < 20; i++)
  32.     {

  33.         b[i] = rand() % 20;
  34.     }
  35.     for (i = 0; i < 20; i++)
  36.     {
  37.         printf("b[%d] = %-3d\n", i, b[i]);
  38.     }
  39.     printf("排序之后\n");
  40.     mppx(b);//调用函数对=数组b进行排序
  41. }
复制代码

-----------------------------------------------------------------------------------------------------------------------
Microsoft Windows [版本 6.1.7601]
版权所有 (c) 2009 Microsoft Corporation。保留所有权利。

E:\Administrator\Documents\My C>cmd /C "c:\Users\Administrator\.vscode\extensions\ms-vscode.cpptools-0.23.1\debugAdapters\bin\WindowsDebugLauncher.exe --stdin=Microsoft-MIEngine-In-cgfzor0y.cvw --stdout=Microsoft-MIEngine-Out-b3zzwf1o.v24 --stderr=Microsoft-MIEngine-Error-0irwvajd.iqa --pid=Microsoft-MIEngine-Pid-dutcx0ls.r0s --dbgExe=E:\MinGW\bin\gdb.exe --interpreter=mi "
排序之前
b[0] = 8
b[1] = 15
b[2] = 15
b[3] = 13
b[4] = 0
b[5] = 13
b[6] = 18
b[7] = 14
b[8] = 11
b[9] = 1
b[10] = 5
b[11] = 14
b[12] = 7
b[13] = 14
b[14] = 7
b[15] = 11
b[16] = 0
b[17] = 2
b[18] = 9
b[19] = 19
排序之后
a[0] = 8

E:\Administrator\Documents\My C>
=================================
为什么不能正确输出排序后的数组,到底哪里出问题了??????????????
最佳答案
2019-5-21 22:14:15
当将数组作为实参传递到一个函数中时,就是将数组的首地址作为实参,
函数的形参相当于一个指针,mppx函数里的sizeof(a)得到的是指针的大小为8,
而int大小为4,相除得2,所以你的程序只会排序前两个元素。
建议参考如下代码:
  1. /*用冒泡法对20个随机元素的数组排序*/
  2. #include <stdio.h>
  3. #include <time.h>
  4. #include <stdlib.h>
  5. void mppx(int a[],int s)
  6. {
  7.     int i, j, t;
  8.    
  9.    // printf("s=%d",s);
  10.     for (i = 0; i < s; i++)
  11.     {
  12.         for (j = 0; j < (s - 1); j++)
  13.         {
  14.             if (a[j] >= a[j + 1])
  15.             {
  16.                 t = a[j];
  17.                 a[j] = a[j + 1];
  18.                 a[j + 1] = t;
  19.             }
  20.         }
  21.     }
  22.     for (i = 0; i < s; i++)
  23.     {
  24.         printf("a[%d] = %d\n", i, a[i]);
  25.     }
  26. }
  27. int main()
  28. {
  29.     int b[19], i,s;
  30.     srand(time(NULL));
  31.     printf("排序之前\n");
  32.     for (i = 0; i < 20; i++)
  33.     {

  34.         b[i] = rand() % 20;
  35.     }
  36.     for (i = 0; i < 20; i++)
  37.     {
  38.         printf("b[%d] = %-3d\n", i, b[i]);
  39.     }
  40.     printf("排序之后\n");
  41.      s = sizeof(b) / sizeof(b[0]);
  42.     mppx(b,s);//调用函数对=数组b进行排序
  43.     return 0;
  44. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2019-5-21 21:26:07 | 显示全部楼层
  1. /*用冒泡法对20个随机元素的数组排序*/
  2. #include <stdio.h>
  3. #include <time.h>
  4. #include <stdlib.h>
  5. void main()
  6. {
  7.     int i, j, s;
  8.     int arr[20];
  9.     srand(time(NULL));
  10.     for (i = 0; i < 20; i++)
  11.     {
  12.         arr[i] = rand() % 20;
  13.     }

  14.     s = sizeof(arr) / sizeof(arr[0]);
  15.     for (i = 0; i < s; i++)
  16.     {
  17.         for (j = 0; j < (s - 1); j++)
  18.         {
  19.             int t;
  20.             if (arr[j] > arr[j + 1])
  21.             {
  22.                 t = arr[j];
  23.                 arr[j] = arr[j + 1];
  24.                 arr[j + 1] = t;
  25.             }
  26.         }
  27.     }
  28.     for (i = 0; i < s; i++)
  29.     {
  30.         printf("arr[%d] = %d  \n", i, arr[i]);
  31.     }
  32. }
复制代码

============================================================
E:\Administrator\Documents\My C>cmd /C "c:\Users\Administrator\.vscode\extensions\ms-vscode.cpptools-0.23.1\debugAdapters\bin\WindowsDebugLauncher.exe --stdin=Microsoft-MIEngine-In-wh0sgtdm.v55 --stdout=Microsoft-MIEngine-Out-2ykotrdf.ufk --stderr=Microsoft-MIEngine-Error-lto0p5do.blo --pid=Microsoft-MIEngine-Pid-012pmyxn.z01 --dbgExe=E:\MinGW\bin\gdb.exe --interpreter=mi "
arr[0] = 1
arr[1] = 4
arr[2] = 5
arr[3] = 5
arr[4] = 7
arr[5] = 7
arr[6] = 8
arr[7] = 9
arr[8] = 10
arr[9] = 11
arr[10] = 11
arr[11] = 12
arr[12] = 13
arr[13] = 13
arr[14] = 14
arr[15] = 14
arr[16] = 14
arr[17] = 17
arr[18] = 17
arr[19] = 18

E:\Administrator\Documents\My C>
-----------------------------------------------------------------------------------------------------
为啥这样就可以,搞成自定义函数就不行
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-21 22:09:15 | 显示全部楼层
  1. void mppx(int a[])
  2. {
  3.     int i, j, t, s;
  4.     s = sizeof(a) / sizeof(a[0]);
  5.     for (i = 0; i < s; i++)
  6.     {
  7.         for (j = 0; j < (s - 1); j++)
  8.         {
  9.             if (a[j] >= a[j + 1])
  10.             {
  11.                 t = a[j];
  12.                 a[j] = a[j + 1];
  13.                 a[j + 1] = t;
  14.             }
  15.         }
  16.     }
  17.     for (i = 0; i < s; i++)
  18.     {
  19.         printf("a[%d] = %d\n", i, a[i]);
  20.     }
  21. }
复制代码

当数组作为参数时传递的是指针而不是数组本身,也就是a的类型是int*,
所以 s=sizeof(a)/sizeof(a[0])即sizeof(int*)/sizeof(int)=2或1。
所以,在C语言中传递数组时,一般同时还会传递数组的大小:
  1. void mppx(int a[],int s)
  2. {
  3.     int i, j, t;
  4.     for (i = 0; i < s; i++)
  5.     {
  6.         for (j = 0; j < (s - 1); j++)
  7.         {
  8.             if (a[j] >= a[j + 1])
  9.             {
  10.                 t = a[j];
  11.                 a[j] = a[j + 1];
  12.                 a[j + 1] = t;
  13.             }
  14.         }
  15.     }
  16.     for (i = 0; i < s; i++)
  17.     {
  18.         printf("a[%d] = %d\n", i, a[i]);
  19.     }
  20. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-21 22:14:15 | 显示全部楼层    本楼为最佳答案   
当将数组作为实参传递到一个函数中时,就是将数组的首地址作为实参,
函数的形参相当于一个指针,mppx函数里的sizeof(a)得到的是指针的大小为8,
而int大小为4,相除得2,所以你的程序只会排序前两个元素。
建议参考如下代码:
  1. /*用冒泡法对20个随机元素的数组排序*/
  2. #include <stdio.h>
  3. #include <time.h>
  4. #include <stdlib.h>
  5. void mppx(int a[],int s)
  6. {
  7.     int i, j, t;
  8.    
  9.    // printf("s=%d",s);
  10.     for (i = 0; i < s; i++)
  11.     {
  12.         for (j = 0; j < (s - 1); j++)
  13.         {
  14.             if (a[j] >= a[j + 1])
  15.             {
  16.                 t = a[j];
  17.                 a[j] = a[j + 1];
  18.                 a[j + 1] = t;
  19.             }
  20.         }
  21.     }
  22.     for (i = 0; i < s; i++)
  23.     {
  24.         printf("a[%d] = %d\n", i, a[i]);
  25.     }
  26. }
  27. int main()
  28. {
  29.     int b[19], i,s;
  30.     srand(time(NULL));
  31.     printf("排序之前\n");
  32.     for (i = 0; i < 20; i++)
  33.     {

  34.         b[i] = rand() % 20;
  35.     }
  36.     for (i = 0; i < 20; i++)
  37.     {
  38.         printf("b[%d] = %-3d\n", i, b[i]);
  39.     }
  40.     printf("排序之后\n");
  41.      s = sizeof(b) / sizeof(b[0]);
  42.     mppx(b,s);//调用函数对=数组b进行排序
  43.     return 0;
  44. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-6 05:21

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表