鱼C论坛

 找回密码
 立即注册
查看: 2553|回复: 8

冒泡算法指针实现的小疑问

[复制链接]
发表于 2014-3-21 22:50:49 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 谓我心忧 于 2014-3-22 07:58 编辑

最近在研究<c缺陷与陷阱>,里面讲到指针和数组其实大致都是以指针传送的,所以用冒泡算法试验了一下,居然失败了,是我把它写成多维数组了么?最近疏于操作,编码越发不规范,代码如下,还请各位帮一下,编译正常,达不到想要的结果.



  1. #include <stdio.h>

  2. void bubble(int *a, int n);
  3. int main(void)
  4. {
  5.     int a[10], i;
  6.     for(i = 0; i<10; i++)
  7.     {
  8.         scanf("%d", &a[i]);
  9.     }
  10.     printf("go go HAHAHA!~\n");
  11.     bubble(*a, 10);
  12.     for(i = 0; i<10; i++)
  13.     {
  14.         printf("%d\n",a[i]);
  15.     }
  16.     getchar();
  17.     return 0;
  18. }
  19. void bubble(int *a, int n)
  20. {
  21.     int i, j, k;
  22.     for(i = 1; i<n; i++)
  23.     {
  24.         for(j = 0; j < n - i; j++)
  25.         {
  26.             if(*(a+j)>*(a+j+1))
  27.             {
  28.                 k = *(a+j+1);
  29.                 *(a+j+1) = *(a+j);
  30.                 *(a+j) = k;
  31.             }
  32.         }
  33.     }
  34. }     感谢鱼友的回答,我把实参修改了一下(传递的*a改称了a),居然成功执行了,这是为什么,传递a指针指向的数据而不是地址对这个程序有什么影响么,形参都带*阿,更加困惑了...
复制代码


小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2014-3-21 23:08:35 | 显示全部楼层
给你稍微改动一下 能运行的

  1. #include <iostream>
  2. using namespace std;

  3. #include <stdio.h>

  4. void bubble(int *a, int n);
  5. int main(void)
  6. {
  7.         int a[10], i;
  8.         for(i = 0; i<10; i++)
  9.         {
  10.                 scanf("%d", &a[i]);
  11.         }
  12.         printf("go go HAHAHA!~\n");
  13.         bubble(a, 10);
  14.         for(i = 0; i<10; i++)
  15.         {
  16.                 printf("%d\n",a[i]);
  17.         }
  18.     system("pause");
  19.         return 0;
  20. }
  21. void bubble(int *a, int n)
  22. {
  23.         int i, j, k;
  24.         for(i = 1; i<n; i++)
  25.         {
  26.                 for(j = 0; j < n - i; j++)
  27.                 {
  28.                         if(*(a+j)>*(a+j+1))
  29.                         {
  30.                                 k = *(a+j+1);
  31.                                 *(a+j+1) = *(a+j);
  32.                                 *(a+j) = k;
  33.                         }
  34.                 }
  35.         }
  36. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-3-21 23:09:19 | 显示全部楼层
本帖最后由 清明 于 2014-3-21 23:18 编辑

这个值得考虑,手边暂时没C。。。
  • bubble(a, 10);
    貌似a应该传递的是地址吧?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-3-22 07:46:13 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-3-22 07:59:09 | 显示全部楼层
清明 发表于 2014-3-21 23:09
这个值得考虑,手边暂时没C。。。
  • bubble(a, 10);

  • 对,改一下实参之后完美运行,问题是这样有什么区别呢?有点困惑...
    小甲鱼最新课程 -> https://ilovefishc.com
    回复 支持 反对

    使用道具 举报

    发表于 2014-3-22 18:33:37 | 显示全部楼层
    数组名理解成指向数组第一个元素的指针
    小甲鱼最新课程 -> https://ilovefishc.com
    回复 支持 反对

    使用道具 举报

    发表于 2014-3-24 06:48:19 | 显示全部楼层
    谓我心忧 发表于 2014-3-22 07:59
    对,改一下实参之后完美运行,问题是这样有什么区别呢?有点困惑...

    你可以把a跟*a输出一下,看看都是什么
    小甲鱼最新课程 -> https://ilovefishc.com
    回复 支持 反对

    使用道具 举报

    发表于 2014-4-27 21:39:53 | 显示全部楼层
    不错  不错  长见识了
    小甲鱼最新课程 -> https://ilovefishc.com
    回复 支持 反对

    使用道具 举报

    发表于 2014-4-27 21:45:10 | 显示全部楼层
    不错  不错  长见识了
    小甲鱼最新课程 -> https://ilovefishc.com
    回复 支持 反对

    使用道具 举报

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

    本版积分规则

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

    GMT+8, 2025-4-21 05:28

    Powered by Discuz! X3.4

    © 2001-2023 Discuz! Team.

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