鱼C论坛

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

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

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

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

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

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

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

#include <stdio.h>

void bubble(int *a, int n);
int main(void)
{
    int a[10], i;
    for(i = 0; i<10; i++)
    {
        scanf("%d", &a[i]);
    }
    printf("go go HAHAHA!~\n");
    bubble(*a, 10);
    for(i = 0; i<10; i++)
    {
        printf("%d\n",a[i]);
    }
    getchar();
    return 0;
}
void bubble(int *a, int n)
{
    int i, j, k;
    for(i = 1; i<n; i++)
    {
        for(j = 0; j < n - i; j++)
        {
            if(*(a+j)>*(a+j+1))
            {
                k = *(a+j+1);
                *(a+j+1) = *(a+j);
                *(a+j) = k;
            }
        }
    }
}     感谢鱼友的回答,我把实参修改了一下(传递的*a改称了a),居然成功执行了,这是为什么,传递a指针指向的数据而不是地址对这个程序有什么影响么,形参都带*阿,更加困惑了...

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2014-3-21 23:08:35 | 显示全部楼层
给你稍微改动一下 能运行的
#include <iostream>
using namespace std;

#include <stdio.h>

void bubble(int *a, int n);
int main(void)
{
        int a[10], i;
        for(i = 0; i<10; i++)
        {
                scanf("%d", &a[i]);
        }
        printf("go go HAHAHA!~\n");
        bubble(a, 10);
        for(i = 0; i<10; i++)
        {
                printf("%d\n",a[i]);
        }
    system("pause");
        return 0;
}
void bubble(int *a, int n)
{
        int i, j, k;
        for(i = 1; i<n; i++)
        {
                for(j = 0; j < n - i; j++)
                {
                        if(*(a+j)>*(a+j+1))
                        {
                                k = *(a+j+1);
                                *(a+j+1) = *(a+j);
                                *(a+j) = k;
                        }
                }
        }
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

这个值得考虑,手边暂时没C。。。
  • bubble(a, 10);
    貌似a应该传递的是地址吧?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-3-22 07:46:13 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

  • 对,改一下实参之后完美运行,问题是这样有什么区别呢?有点困惑...
    想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
    回复 支持 反对

    使用道具 举报

    发表于 2014-3-22 18:33:37 | 显示全部楼层
    数组名理解成指向数组第一个元素的指针
    想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
    回复 支持 反对

    使用道具 举报

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

    你可以把a跟*a输出一下,看看都是什么
    想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
    回复 支持 反对

    使用道具 举报

    发表于 2014-4-27 21:39:53 | 显示全部楼层
    不错  不错  长见识了
    想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
    回复 支持 反对

    使用道具 举报

    发表于 2014-4-27 21:45:10 | 显示全部楼层
    不错  不错  长见识了
    想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
    回复 支持 反对

    使用道具 举报

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

    本版积分规则

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

    GMT+8, 2024-12-26 10:59

    Powered by Discuz! X3.4

    © 2001-2023 Discuz! Team.

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