| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 467 人关注过本帖
标题:求大神帮忙看看这个排序哪儿错了
只看楼主 加入收藏
l14414978
Rank: 1
等 级:禁止发言
帖 子:9
专家分:0
注 册:2012-12-25
结帖率:0
收藏
 问题点数:0 回复次数:6 
求大神帮忙看看这个排序哪儿错了
提示: 作者被禁止或删除 内容自动屏蔽
搜索更多相关主题的帖子: 看看 
2012-12-25 16:11
yaobao
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:蒙面侠
威 望:4
帖 子:1854
专家分:4121
注 册:2012-10-25
收藏
得分:0 
感觉逻辑上不是很合理啊,这样怕有遗漏的地方啊,用for循环呢?

认认真真的学习,踏踏实实的走路:戒骄戒躁!!!
2012-12-25 16:13
l14414978
Rank: 1
等 级:禁止发言
帖 子:9
专家分:0
注 册:2012-12-25
收藏
得分:0 
回复 2楼 yaobao
提示: 作者被禁止或删除 内容自动屏蔽
2012-12-25 16:14
wkz2012
Rank: 4
等 级:业余侠客
帖 子:123
专家分:253
注 册:2012-12-13
收藏
得分:0 
以下是引用l14414978在2012-12-25 16:11:24的发言:

描述
将四个整数进行从小到大的顺序排列,
 
输入
四个整数
 
产量
从小到大输出这四个数
 
我的答案
#include
void main()
{
int a,b,c,d,t;
scanf("%d%d%d%d",&a,&b,&c,&d);
if(a>b){t=a;a=b;b=t;}
if(b>c){t=b;b=c;c=t;}
if(c>d){t=c;c=d;d=t;}
if(b>c){t=b;b=c;c=t;}
if(a>b){t=a;a=b;b=t;}
if(b>c){t=b;b=c;c=t;}

printf("%d,%d,%d,%d\n",a,b,c,d);
 
}
这些代码是不是和上面重复了,这种代码是读起来很费脑的,还是用比较容易理解的吧,比如冒泡排序法
https://bbs.bccn.net/thread-393395-3-1.html

我了个去的编程!
2012-12-25 16:21
ksddah
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:53
专家分:135
注 册:2012-12-11
收藏
得分:0 
程序代码:
//简单的冒泡排序
#include<stdio.h>
int main()
{
    int a[4];
    int t,i,j;
    printf("请输入四个整数:");
    for(t=0;t<4;t++)
    {
        scanf("%d",&a[t]);
    }
    for(j=0;j<4;j++)
    {
        for(i=j;i<3;i++)
        {
            int temp;
            if(a[i]>a[i+1])
            {
                temp=a[i];
                a[i]=a[i+1];
                a[i+1]=temp;
            }
        }
    }
    
    for(t=0;t<4;t++)
    {
        printf("%4d",a[t]);
    }
    return 0;
}
2012-12-25 17:37
张时杰
Rank: 1
等 级:新手上路
帖 子:19
专家分:6
注 册:2012-12-25
收藏
得分:0 
冒泡法最好了

新手掩面飘过...
2012-12-25 20:26
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
程序代码:
#include<stdio.h>
void main()
{
    int a,b,c,d,t;
    scanf("%d%d%d%d",&a,&b,&c,&d);
    if(a>b){t=a;a=b;b=t;}
    if(b>c){t=b;b=c;c=t;}
    if(c>d){t=c;c=d;d=t;}
    //往上三行的功能是把最大的放到d

//  if(b>c){t=b;b=c;c=t;}
    if(a>b){t=a;a=b;b=t;}
    if(b>c){t=b;b=c;c=t;}
    //这两行应该是把abc中最大的放到c,可惜写反了,
    //应该先比较ab

//  if(b>c){t=b;b=c;c=t;}
    if(a>b){t=a;a=b;b=t;}
    //想想也知道,应该比较最前面两个了

    printf("%d,%d,%d,%d\n",a,b,c,d);
}
//其实还是冒泡排序吧。。。
//用循环,就可以少些很多行代码了


[fly]存在即是合理[/fly]
2012-12-25 20:37
白杨的记忆
Rank: 1
等 级:新手上路
帖 子:0
专家分:0
注 册:2012-12-25
收藏
得分:0 
这个用冒泡排序简单
2012-12-25 22:05
快速回复:求大神帮忙看看这个排序哪儿错了
数据加载中...
 
   



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

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