| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 731 人关注过本帖
标题:冒泡排序中的错误
只看楼主 加入收藏
erdongwei
Rank: 2
等 级:论坛游民
帖 子:9
专家分:13
注 册:2012-3-17
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:11 
冒泡排序中的错误
我新来的,哪位大哥能帮忙看看这个程序:
#include<stdio.h>
void bubblesort(int a[10]);
int main()
{
    int i,a[10];
    for(i=0;i<9;i++)
        scanf("%d",a[i]);
    bubblesort(a);
    for(i=1;i<=10;i++)
        printf("%d ",a[10-i]);
    printf("\n");
    return 0;
}

void bubblesort(int a[10])
{
    int i,j,m;
    for(i=0;i<9;i++){
        for(j=0;j<9-i;j++){
            if(a[j]>a[j+1]){
                m=a[j];
                a[j]=a[j+1];
                a[j+1]=m;
            }
            else ;
        }
    }
}
为什么在Vc++中编译时没有错,却不能运行呢?谢谢啦!
搜索更多相关主题的帖子: void 大哥 include return 
2012-03-17 14:42
nicum
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:180
专家分:712
注 册:2011-2-1
收藏
得分:0 
#include<stdio.h>
void bubblesort(int a[10]);//void bubblesort(int *);
int main()
{
    int i,a[10];
    for(i=0;i<9;i++)
        scanf("%d",a[i]);// scanf("%d",&a[i]);
    bubblesort(a);
    for(i=1;i<=10;i++)
        printf("%d ",a[10-i]);
    printf("\n");
    return 0;
}

void bubblesort(int a[10])//void bubblesort(int * a)
{
    int i,j,m;
    for(i=0;i<9;i++){
        for(j=0;j<9-i;j++){
            if(a[j]>a[j+1]){
                m=a[j];
                a[j]=a[j+1];
                a[j+1]=m;
            }
            else ;//这句可以不要
        }
    }
}
2012-03-17 20:21
erdongwei
Rank: 2
等 级:论坛游民
帖 子:9
专家分:13
注 册:2012-3-17
收藏
得分:0 
这个我懂,但之前没有这个,也不能运行,
我就加上了这个,还是不能运行,编译时没报错啊
2012-03-17 21:58
shuijiashui
Rank: 2
等 级:论坛游民
帖 子:43
专家分:85
注 册:2009-9-1
收藏
得分:10 
scanf("%d",a[i]);//=================&a[i]  
   
2012-03-18 00:34
erdongwei
Rank: 2
等 级:论坛游民
帖 子:9
专家分:13
注 册:2012-3-17
收藏
得分:0 
对了!谢谢啦!
如果是字符型的数组,还需要&吗
2012-03-18 12:43
Invariably
Rank: 2
等 级:论坛游民
帖 子:54
专家分:46
注 册:2010-9-18
收藏
得分:5 
#include<stdio.h>
void bubblesort(int a[10]);
int main()
{
    int i,a[10];
    printf("请输入10个整数:");
    for(i=0;i<10;i++)
        scanf("%d",&a[i]);
    bubblesort(a);
    for(i=1;i<=10;i++)
        printf("%d ",a[10-i]);
    printf("\n");
    return 0;
}

void bubblesort(int a[10])
{
    int i,j,m;
    for(i=0;i<9;i++){
        for(j=0;j<9-i;j++){
            if(a[j]>a[j+1]){
                m=a[j];
                a[j]=a[j+1];
                a[j+1]=m;
            }
            else ;
        }
    }
}
字符型的还是要用取地址符“&”的,可以去看看scanf()函数的详细用法;http://baike.baidu.com/view/1390039.htm
2012-03-18 13:46
lyswwr
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:53
专家分:124
注 册:2011-7-3
收藏
得分:5 
只有数组名时候就不要取地址符号,因为数组就是表示地址:
2012-03-18 14:12
C_戴忠意
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:2
帖 子:575
专家分:1349
注 册:2011-10-21
收藏
得分:0 
路过看看丶貌似冒泡排序不是很难丶

编程之路定要走完……
2012-03-18 14:49
erdongwei
Rank: 2
等 级:论坛游民
帖 子:9
专家分:13
注 册:2012-3-17
收藏
得分:0 
懂了,谢谢各位!
2012-03-18 23:00
HUYOULIANGHH
Rank: 1
等 级:新手上路
帖 子:5
专家分:1
注 册:2011-8-29
收藏
得分:0 
兄弟,这不是冒泡排序法,这是直接插入排序法,好好看看书分清两者的差别,提醒一下第二个for循环有误,自己去想为什么吧!
2012-03-19 10:17
快速回复:冒泡排序中的错误
数据加载中...
 
   



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

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