| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 867 人关注过本帖
标题:新人求解,关于函数调用实现冒泡排序的问题?
只看楼主 加入收藏
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
结帖率:90.24%
收藏
已结贴  问题点数:20 回复次数:17 
新人求解,关于函数调用实现冒泡排序的问题?
#include<stdio.h>
void main()
{
void cmp(int,int);
int x,i,j,a[10];
printf("the array is :\n");
for(i=0;i<10;i++)
scanf("%d",&a[i]);
for(j=0;j<9;j++)
{
for(i=0;i<9-j;i++)
{
cmp(a[i],a[i+1]);

}
}
printf("The fresh array is:\n");
for(i=0;i<10;i++)
printf("%d\t",a[i]);
}

void cmp(int x,int y)
{
int z;
if(x>y)
{
z=x;
x=y;
y=z;
}
}
2014-10-09 11:03
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
为什么此程序实现不了冒泡排序,我感觉没神马错误啊~难道是形参和实参的问题~求大神解答撒~

既然还有不甘心
就还没到放弃的时候~
2014-10-09 11:04
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:20 
传值问题还是传址问题

DO IT YOURSELF !
2014-10-09 11:10
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
回复 3 楼 wp231957
帮我修改一下吧~谢谢

既然还有不甘心
就还没到放弃的时候~
2014-10-09 11:12
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
#include<stdio.h>
void main()
{
void cmp(int a[],int n);
int x,i,j,a[10];
printf("the array is :\n");
for(i=0;i<10;i++)
scanf("%d",&a[i]);
cmp(a,10);
for(i=0;i<10;i++)
printf("%d\t",a[i]);
}

void cmp(int a[],int n)
{
int i,j,x;
for(j=0;j<n-1;j++)
{
for(i=0;i<n-1-j;i++)
{
if(a[i]>a[i-1])
{
x=a[i];
a[i]=a[i+1];
a[i+1]=x;
}
}
}
}

我把程序改了一下,结果发现这个程序可以实现冒泡排序~ 彻底晕了~都是函数的调用问题~搞不懂这两程序有神马区别撒~

既然还有不甘心
就还没到放弃的时候~
2014-10-09 11:15
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
回复 3 楼 wp231957
是不是必须引用指针才可以实现那个冒泡排序~我下面这个为啥又能实现冒泡排序了撒~搞不懂

既然还有不甘心
就还没到放弃的时候~
2014-10-09 11:17
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
大约这样子就可以了
程序代码:
#include<stdio.h>
#define N 5
void cmp(int*,int*);

int main()
{
    
    int i,j,a[N];
    printf("the array is :\n");
    for(i=0;i<N;i++)
        scanf("%d",&a[i]);
    for(j=0;j<N;j++)
    {
        for(i=0;i<N-j;i++)
        {
            cmp(&a[i],&a[i+1]);

        }
    }
    printf("The fresh array is:\n");
    for(i=0;i<N;i++)
        printf("%d\t",a[i]);
    return 0;
}

void cmp(int* x,int* y)
{
    int z;
    if(*x>*y)
    {
        z=*x;
        *x=*y;
        *y=z;
    }
}

DO IT YOURSELF !
2014-10-09 11:19
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
回复 7 楼 wp231957
嗯 谢谢你哈~ 果然是指针 我还没看到~等我看到了再回头看看~

既然还有不甘心
就还没到放弃的时候~
2014-10-09 11:24
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
以下是引用S140131022在2014-10-9 11:15:28的发言:

#include<stdio.h>
void main()
{
void cmp(int a[],int n);
int x,i,j,a[10];
printf("the array is :\n");
for(i=0;i<10;i++)
scanf("%d",&a);
cmp(a,10);
for(i=0;i<10;i++)
printf("%d\t",a);
}

void cmp(int a[],int n)
{
int i,j,x;
for(j=0;j<n-1;j++)
{
for(i=0;i<n-1-j;i++)
{
if(a>a)
{
x=a;
a=a;
a=x;
}
}
}
}

我把程序改了一下,结果发现这个程序可以实现冒泡排序~ 彻底晕了~都是函数的调用问题~搞不懂这两程序有神马区别撒~

你这里的函数第一个参数就是传的地址(指针)

DO IT YOURSELF !
2014-10-09 11:28
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
回复 9 楼 wp231957
嗯嗯  谢谢你 ~ 我现在学学指针~

既然还有不甘心
就还没到放弃的时候~
2014-10-09 14:21
快速回复:新人求解,关于函数调用实现冒泡排序的问题?
数据加载中...
 
   



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

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