| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 9488 人关注过本帖
标题:找出10个数中最大的两个数,怎么编啊
只看楼主 加入收藏
huangruoxu
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2008-12-9
收藏
 问题点数:0 回复次数:44 
找出10个数中最大的两个数,怎么编啊
大哥大姐帮帮忙
搜索更多相关主题的帖子: 大哥 最大的 
2008-12-11 14:09
dillon
Rank: 1
等 级:新手上路
威 望:2
帖 子:183
专家分:0
注 册:2008-10-6
收藏
得分:0 
#include"stdio.h"
void main()
{
    int a[10]={1,2,3,4,5,6,7,8,9,0};
    int i,j=0;
    for(i=0;i<10;i++)
    {
        if(a[i]>=j)
           j=a[i];
     }
     printf("%d",j);
}
收到的鲜花
  • missiyou2008-12-13 21:06 送鲜花  50朵  
2008-12-11 16:22
longxigen
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2008-12-11
收藏
得分:0 
可以现对这一组数进行从小到大(或从大到小)排序,然后取后两个(或前两个)即为最大的两个数。
以下是按从小到大的排序方法写的:
#include<stdio.h>
void main()
{
 int i,j;
 float a[10],max1,max2,t;
 printf("input 10 numbers:\n");
 for(i=0;i<10;i++)
 scanf("%f",&a[i]);
 printf("\n");
 for(j=0;j<9;j++)
  for(i=0;i<9-j;i++)
   if(a[i]>a[i+1])
    {
     t=a[i];
     a[i]=a[i+1];
     a[i+1]=t;
     }
 printf("最大的两个数为:\n");
 printf("%f,%f\n",a[8],a[9]);
}
收到的鲜花
  • missiyou2008-12-13 21:08 送鲜花  50朵   附言:!
2008-12-11 16:53
longxigen
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2008-12-11
收藏
得分:0 
回复 第2楼 dillon 的帖子
这个怕不对哦 他说的是十个数中并不是1到10,而是任意的十个数,而且是找出其中最大的两个。你的程序只输出了最大的那个数。
2008-12-11 16:56
柳无痕
Rank: 1
来 自:浙江省
等 级:新手上路
帖 子:57
专家分:0
注 册:2008-12-10
收藏
得分:0 
2楼的a[i-1]就是第二大的数吧
2008-12-11 17:10
longxigen
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2008-12-11
收藏
得分:0 
回复 第5楼 柳无痕 的帖子
不是吧 二楼的那段程序其实并没有对数组重新排序 只是在找最大的那个数
2008-12-11 17:18
zrf625278699
Rank: 1
等 级:新手上路
帖 子:36
专家分:0
注 册:2008-10-14
收藏
得分:0 
回复 楼主 huangruoxu 的帖子
遍历三遍 分别找出前三大的数
#include <stdio.h>
#define  MIN  -100000
int main()
{
    int a[10];
    int i,t;
    int first,second,third;

    for(i=0;i<10;i++) scanf("%d",&a[i]);

    first=MIN;
    for(i=0;i<10;i++)
        if(a[i]>first) { first=a[i];t=i;}
    a[t]=MIN;

    second=MIN;
    for(i=0;i<10;i++)
        if(a[i]>second) { second=a[i];t=i;}
    a[t]=MIN;

    third=MIN;
    for(i=0;i<10;i++)
        if(a[i]>third) { third=a[i];t=i;}
    a[t]=MIN;

    printf("%d %d %d",first,second,third);

    return 0;
}
2008-12-11 18:42
ws小徐
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2008-12-4
收藏
得分:0 
3楼的朋友写的程序有一点没看懂:
for(j=0;j<9;j++)
  for(i=0;i<9-j;i++)
   if(a[i]>a[i+1])
    {
     t=a[i];
     a[i]=a[i+1];
     a[i+1]=t;
     }
不知哪位仁兄能给我解释一下~~~

我是个菜鸟,如果提的问题太菜了请大家谅解!
2008-12-11 19:14
广陵绝唱
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:29
帖 子:3607
专家分:1709
注 册:2008-2-15
收藏
得分:0 
回复 第8楼 ws小徐 的帖子
冒泡法排序。
2008-12-11 19:18
arquehi
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2008-12-8
收藏
得分:0 
我用函数调用法来做的.一定行
#include "stdio.h"
int findmax(int a[],int s);

int  main()
{
    int i;
         int b[10]={10,9,5,6,3,7,8,15,3,1};
         printf("%3d\n",findmax(b,10));
   
}
int findmax(int a[],int s)
{
    int i;
    int max=a[0];
    for(i=1;i<s;i++)
    {
        if(a[i]>max)
        max=a[i];
    }
    return max;
}
2008-12-11 20:34
快速回复:找出10个数中最大的两个数,怎么编啊
数据加载中...
 
   



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

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