| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 402 人关注过本帖
标题:大神们,帮帮忙,找下错误!!
只看楼主 加入收藏
GKL932939348
Rank: 1
来 自:重庆
等 级:新手上路
帖 子:21
专家分:9
注 册:2013-11-5
结帖率:85.71%
收藏
已结贴  问题点数:40 回复次数:4 
大神们,帮帮忙,找下错误!!
  14、输入a1,a2,a3,……,a20,将它们从小到大排序后输出,并给出现在每个元素所对应的原来次序。例如:输入:27,3,25,27,14,39
  输出:   3     2
           14    5
           25    3
           27    1
           27    4
           39    6
--------------------------------------------------------------
当我的数组元素个数与要输入的个数一样是才正确,其他就会少一个数。帮帮忙。
--------------------------------------------------------------
void exe14()
{   
    int a[1024],b[1024],i,n,j,t;
    printf("请输入要输入的数字个数:\n");
    scanf("%d",&n);
    printf("请输入数字:\n");
    for(i=0;i<n;i++)
    {
        scanf("%d",&a[i]);
        b[i]=a[i];
    }
    for(j=0;j<n;j++)
    {
        for(i=0;i<n;i++)
        {
            if(a[i]>a[i+1])
            {
                t=a[i];
                a[i]=a[i+1];
                a[i+1]=t;
            }
        }
    }
    printf("-------------------\n");
    printf("-------------------\n");
    for(i=0;i<n;i++)
    {
        for(j=0;j<n;j++)
        {
            if(a[i]==b[j])
            {
                printf("  %d  ",a[i]);
                printf("%d\n",j+1);
            }
        }
    }
}
搜索更多相关主题的帖子: 元素 
2013-11-26 18:45
heroinearth
Rank: 10Rank: 10Rank: 10
来 自:云南曲靖
等 级:青峰侠
帖 子:430
专家分:1506
注 册:2011-10-24
收藏
得分:14 
    for(j=0;j<n;j++)
    {
        for(i=0;i<n;i++)//你下面用i+1,条件只能是i<n-1
        {
            if(a[i]>a[i+1])
            {
                t=a[i];
                a[i]=a[i+1];
                a[i+1]=t;
            }
        }
    }

还有你的输出不明白要实现什么
程序代码:
#include "stdio.h"
int main(void)
{
    int a[1024],b[1024],i,n,j,t;
    printf("请输入要输入的数字个数:\n");
    scanf("%d",&n);
    printf("请输入数字:\n");
    for(i=0;i<n;i++)
    {
        scanf("%d",&a[i]);
        b[i]=a[i];
    }
    for(j=0;j<n;j++)
    {
        for(i=0;i<n-1;i++)
        {
            if(a[i]>a[i+1])
            {
                t=a[i];
                a[i]=a[i+1];
                a[i+1]=t;
            }
        }
    }
    printf("-------------------\n");
    printf("-------------------\n");
    for(i=0;i<n;i++)
    {
        printf("  %d  %d\n",a[i],b[i]);
    }
    return 0;
}




[ 本帖最后由 heroinearth 于 2013-11-26 19:09 编辑 ]
2013-11-26 18:53
韶志
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:斗气大陆
等 级:贵宾
威 望:44
帖 子:2223
专家分:13592
注 册:2013-3-22
收藏
得分:14 
呵呵   都会犯小错误
void exe14()
{   
    int a[1024],b[1024],i,n,j,t;
    printf("请输入要输入的数字个数:\n");
    scanf("%d",&n);
    printf("请输入数字:\n");
    for(i=0;i<n;i++)
    {
        scanf("%d",&a[i]);
        b[i]=a[i];
    }
    for(j=0;j<n-1;j++)  //改为n-1就OK了

    {
        for(i=0;i<n-1;i++)  //改为n-1就OK了
        {
            if(a[i]>a[i+1])
            {
                t=a[i];
                a[i]=a[i+1];
                a[i+1]=t;
            }
        }
    }
    printf("-------------------\n");
    printf("-------------------\n");
    for(i=0;i<n;i++)
    {
        for(j=0;j<n;j++)
        {
            if(a[i]==b[j])
            {
                printf("  %d  ",a[i]);
                printf("%d\n",j+1);
            }
        }
    }
}

三十年河东,三十年河西,莫欺少年穷!
2013-11-26 19:49
wht750109
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:49
专家分:151
注 册:2013-10-21
收藏
得分:14 
void exe14()
{   
    int a[1024],b[1024],i,n,j,t;
    printf("请输入要输入的数字个数:\n");
    scanf("%d",&n);
    printf("请输入数字:\n");
    for(i=0;i<n;i++)
    {
        scanf("%d",&a[i]);
        b[i]=a[i];
    }
    for(j=0;j<n;j++)     这里j<n-1就行,j<n等于排好后多运行一遍。
    {
        for(i=0;i<n;i++)          这里一定要i<n-1,因为n-1次交换正好n个数,再多循环一次把第N+1个未定义的数排了进来,如果交换,可能少一个数,多一个未知的数。
        {
            if(a[i]>a[i+1])
            {
                t=a[i];
                a[i]=a[i+1];
                a[i+1]=t;
            }
        }
    }
    printf("-------------------\n");
    printf("-------------------\n");
    for(i=0;i<n;i++)
    {
        for(j=0;j<n;j++)
        {
            if(a[i]==b[j])
            {
                printf("  %d  ",a[i]);
                printf("%d\n",j+1);
            }
        }
    }
}
2013-11-26 22:06
GKL932939348
Rank: 1
来 自:重庆
等 级:新手上路
帖 子:21
专家分:9
注 册:2013-11-5
收藏
得分:0 
谢了!万分感谢!!!!!!!!!!!!!!
2013-11-27 07:05
快速回复:大神们,帮帮忙,找下错误!!
数据加载中...
 
   



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

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