| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 7074 人关注过本帖
标题:随机输入一组数(个数不确定),再冒泡排序输出,如何实现?
只看楼主 加入收藏
小花之清
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2013-3-27
结帖率:75%
收藏
 问题点数:0 回复次数:8 
随机输入一组数(个数不确定),再冒泡排序输出,如何实现?
程序代码:
#include<stdio.h>
void main()
{  void maopao(int *x,int n);
    int i=0,n=1,m;
    int a[100];
    printf("输入一组整数按ctrl+d结束\n");
    while(scanf("%d",&a[i]))n++;//循环输入一组数
    printf("%d\n",n);
    maopao(a,n);//冒泡法
    printf("排序后的一组整数\n");
    for(m=0;m<=n;m++)
    printf("  %d",a[m]);
    printf("\n");
}
void maopao(int *x,int n)
{int j,temp,k;
for(j=0;j<n;j++)
  for(k=0;k<n-j;k++)
  {if(x[k]<x[k+1])
      {temp=x[k];
       x[k]=x[k+1];
       x[k+1]=temp;}
  }
}
    以上是我的代码,调试有问题,大侠看下。
搜索更多相关主题的帖子: 如何 
2013-03-28 00:01
shmilyflf
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:5
帖 子:356
专家分:1008
注 册:2012-12-9
收藏
得分:0 
#include<stdio.h>
void main()
{  
    void maopao(int *x,int n);
    int i=0,n=1,m;
    int a[100];
    printf("输入一组整数按ctrl+d结束\n");
    while(scanf("%d",&a[i++]))n++;//循环输入一组数
    //这里的i你要让它增加,要不你只能得到最后输入的一个值
    n--;//你是n=1开始的,所以最后要减去1才是你输入的数的个数
    printf("%d\n",n);
    maopao(a,n);//冒泡法
    printf("排序后的一组整数\n");
    for(m=0;m<n;m++)
        printf("  %d",a[m]);
    printf("\n");
}
void maopao(int *x,int n)
{
    int j,temp,k;
    for(j=0;j<n;j++)
        for(k=0;k<n-j-1;k++)
        {
            if(x[k]<x[k+1])
            {
                temp=x[k];
                x[k]=x[k+1];
                x[k+1]=temp;
            }
        }
}
2013-03-28 00:30
小花之清
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2013-3-27
收藏
得分:0 
回复 2楼 shmilyflf
运行了还是不行,你提出的i++我疏忽了,我原来是将n个i共用的,后来将i++换成了n++。
2013-03-28 12:11
小花之清
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2013-3-27
收藏
得分:0 
回复 3楼 小花之清
n和i
2013-03-28 12:11
helloUJS
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:168
专家分:731
注 册:2013-3-27
收藏
得分:0 
#include<stdio.h>
 main()
{  void maopao(int *x,int n);
    int i=0,n=1,m;
    int a[100];
    printf("输入一组整数按ctrl+d结束\n");
    while(scanf("%d",&a[i++]))n++;//循环输入一组数
    n--;
    printf("%d\n",n);
    maopao(a,n);//冒泡法
    printf("排序后的一组整数\n");
    for(m=0;m<n;m++)
    printf("  %d",a[m]);
    printf("\n");
 }
void maopao(int *x,int n)
{int j,temp,k;
for(j=n-1;j>0;j--)
  for(k=0;k<j;k++)
  {if(x[k]<x[k+1])
      {temp=x[k];
       x[k]=x[k+1];
       x[k+1]=temp;}
  }
}改成这样,可以了
2013-03-28 20:40
小花之清
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2013-3-27
收藏
得分:0 
回复 5楼 helloUJS
图片附件: 游客没有浏览图片的权限,请 登录注册
2013-03-28 20:53
小花之清
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2013-3-27
收藏
得分:0 
回复 5楼 helloUJS
运行了还是不行。
2013-03-28 20:54
helloUJS
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:168
专家分:731
注 册:2013-3-27
收藏
得分:0 
输入数据格式错了,不能用逗号分隔,使用空格
2013-03-28 20:55
shmilyflf
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:5
帖 子:356
专家分:1008
注 册:2012-12-9
收藏
得分:0 
…………………………
2013-03-29 00:21
快速回复:随机输入一组数(个数不确定),再冒泡排序输出,如何实现?
数据加载中...
 
   



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

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