| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1158 人关注过本帖
标题:新手求解 冒泡算法。。
取消只看楼主 加入收藏
老实写码
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2017-5-30
结帖率:50%
收藏
已结贴  问题点数:20 回复次数:2 
新手求解 冒泡算法。。
c语言小白 求大佬们指教
要定义一个有五个元素一维数组,输入五个数,从大到小排列后 输出次最大值(第二大的数) 我写的实现代码如下
#include <stdio.h>
int main()
{

    int a[5],j,i,temp;
    for(i=0;i<=4;i++)
        scanf("%d",&a[i]);
    for(i=0;i<=4;i++)
        for(j=0;j<=4-i;j++)
            {  if(a[j+1]>a[j])
            {temp=a[j]; a[j]=a[j+1]; a[j+1]=temp;}}
    printf("次最大值=%d",a[1]);
}
有几个花括号可能是不需要的 我习惯加上了 但是问题是语法没报错 输出后的结果是最大值 我又把五个数都输出后发现a[0]的值自动变成了32767 我是64位系统 int类型最大值是2的31次方 而且我输入测试的数都很小没有溢出 为什么会这样呢?
搜索更多相关主题的帖子: include 最大值 c语言 元素 
2017-05-30 21:23
老实写码
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2017-5-30
收藏
得分:0 
回复 2楼 林月儿
厉害了我的哥 现在成功实现了 但是为什么下标越界了呢 能给下详解吗
2017-05-30 21:40
老实写码
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2017-5-30
收藏
得分:0 
回复 4楼 renkejun1942
谢谢哥~我明白了
2017-05-30 22:37
快速回复:新手求解 冒泡算法。。
数据加载中...
 
   



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

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