| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 867 人关注过本帖
标题:新人求解,关于函数调用实现冒泡排序的问题?
只看楼主 加入收藏
Rick_gu
Rank: 3Rank: 3
等 级:论坛游侠
威 望:3
帖 子:37
专家分:108
注 册:2014-5-29
收藏
得分:0 
main() {
    int i,j,temp;
    int a[7]= {1,2,6,8,3,8,9};
    for(i=0;i<7;i++)

        for (j = i; j < 7;j++)
        {
            if (a[i] > a[j])
            {
                temp = a[i];
                a[i] = a[j];
                a[j] = temp;
            }
        }
        for (i = 0; i < 7; i++)
        {
            printf("%d\n", a[i]);
        }
    getchar();

}
2014-10-09 16:20
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
程序修改如下完成了冒泡排序~希望对大家有帮助撒~
#include<stdio.h>
void main()
{
void cmp(int*x,int*y);
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 16:56
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
回复 3 楼 wp231957
#include<stdio.h>
#include<string.h>
void main()
{
    void cmp(char*x,char*y);
    char *word[]={"Follow me","Basic","Great wall","Fortran","Computer Design"};
    int i,j,n=5;
    for(i=0;i<5;i++)
    puts(word[i]);
    for(j=0;j<n-1;j++)
    {
        for(i=0;i<n-1-j;i++)
            cmp(word[i],word[i+1]);
    }
    printf("\n");
    for(i=0;i<5;i++)
    puts(word[i]);
}

void cmp(char*x,char*y)
{
char *p;
if(strcmp(x,y)>0)
{
p=x;
x=y;
y=p;
}
}

这个为啥又实现不了冒泡排序~

既然还有不甘心
就还没到放弃的时候~
2014-10-14 15:34
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
作为交换的临时变量 他显然应该是实体 而不是虚指针

DO IT YOURSELF !
2014-10-15 08:22
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
回复 14 楼 wp231957
#include<stdio.h>
#include<string.h>
void main()
{
void sort(char*name[],int n);
void print(char*name[],int n);
char *name[]={"Follow me","Basic","Great Wall","FORTRAN","Computer design"};
int n=5;
sort(name,n);
print(name,n);
}

void sort(char*name[],int n)
{
char *temp;
int i,j;
for(j=0;j<n-1;j++)
{
for(i=0;i<n-1-j;i++)
{
if(strcmp(name[i],name[j])>0)
{
temp=name[i];
name[i]=name[j];
name[j]=temp;
}
}
}
}

void print(char *name[],int n)
{
int i;
for(i=0;i<n;i++)
printf("%s\n",name[i]);
}

那这个也是交换的虚指针为何功能得以实现呢

既然还有不甘心
就还没到放弃的时候~
2014-10-15 20:52
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
回复 14 楼 wp231957
这个是书上的程序~ 我想按照自己的方法编~但是每次编出来都会有错误~这是个人艰不拆A~

既然还有不甘心
就还没到放弃的时候~
2014-10-15 20:53
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
回复 14 楼 wp231957
实参是两指针~形参也是两指针~形参值发生交换无法传给实参,所以此冒泡排序未得以实现~虽然此函数貌似传地,其实仍是传值。。固交换失败~~~~

我这个理解对不对??

既然还有不甘心
就还没到放弃的时候~
2014-10-15 21:06
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
请对比13楼和15楼的代码   他们是截然不同的
一个是指向字符的指针  指向一个字符串
一个是指向字符串数组的指针   指向一组字符串

DO IT YOURSELF !
2014-10-15 22:36
快速回复:新人求解,关于函数调用实现冒泡排序的问题?
数据加载中...
 
   



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

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