| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 9488 人关注过本帖
标题:找出10个数中最大的两个数,怎么编啊
只看楼主 加入收藏
h0000005
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2008-12-13
收藏
得分:0 
回复 第10楼 arquehi 的帖子
來學習經驗
永遠上進
2008-12-13 21:13
missiyou
Rank: 5Rank: 5
等 级:贵宾
威 望:16
帖 子:531
专家分:218
注 册:2007-10-9
收藏
得分:0 
怎么对我的算法,没人顶啊,哎,早知道不发了,真是的,想破脑子了
void max(int *a)
{
  int n,m,i,j;
  n=m=0;
for(i=1;i<10;i++)
{
  if(m<a[i])
{ n=m;m=a[i];}
  else if(a[i]>n)
  n=a[i];

}
printf("%d %d",m,n);
}
2008-12-13 21:42
zqy110007
Rank: 3Rank: 3
来 自:外太空
等 级:论坛游民
威 望:6
帖 子:1493
专家分:82
注 册:2008-11-19
收藏
得分:0 
大家都来发了啊?
我也来一个,等等

每个人都是蛤蟆,只是井的大小不同罢了.
沙石下的泉水,挖得越深,泉水越清.
2008-12-13 22:00
zqy110007
Rank: 3Rank: 3
来 自:外太空
等 级:论坛游民
威 望:6
帖 子:1493
专家分:82
注 册:2008-11-19
收藏
得分:0 
程序代码:
#include <time.h>
#include <stdio.h>
#include <conio.h>

#define M 10

/*交换函数*/
int change(int *a,int *b){
  int m;
  m=*a;
  *a=*b;
  *b=m;
}

int main(void){
  int num[M]={0};
  int i,j;

  srand((unsigned)time(NULL));
  printf("The number is:\n");
  for(i=0;i<M;i++){
    num[i]=(rand()%M)+1;
    printf("%d ",num[i]);
  }
  for(i=0;i<M;i++)
    for(j=M-1;j>i;j--){
      if(num[i]<num[j])
        change(&num[i],&num[j]);
    }
  printf("\nThe max is %d and %d.\n",num[0],num[1]);
  getch();
  return 0;
}

每个人都是蛤蟆,只是井的大小不同罢了.
沙石下的泉水,挖得越深,泉水越清.
2008-12-13 22:11
ukger
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2008-12-13
收藏
得分:0 
#include"stdio.h"
void main()
{
    int a[10]={1,2,3,4,5,6,7,8,9,0};
    int i,j=a[0],k=a[0];
    for(i=0;i<10;i++)
        if(a[i]>=j)
          {
            k=j;
            j=a[i];
          }
     printf("%d,%d\n",j,k);
}
2008-12-13 22:13
missiyou
Rank: 5Rank: 5
等 级:贵宾
威 望:16
帖 子:531
专家分:218
注 册:2007-10-9
收藏
得分:0 
#include <stdio.h>
#include <stdlib.h>
void max(int *a)
{
  int n,m,i,j;
  n=m=0;
for(i=1;i<10;i++)
{
  if(m<a[i])
{ n=m;m=a[i];}
  else if(a[i]>n)
  n=a[i];

}
printf("%d %d",m,n);
}
int main(int argc, char *argv[])
{
  int m[10]={2,45,52,2,78,65,33,2,4,5};
  max(m);
  system("PAUSE");   
  return 0;
}
这个不好吗
2008-12-13 22:19
隨心所欲
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2008-12-13
收藏
得分:0 
上边的有些没看明白 可能我是菜鸟的原因吧
2008-12-13 22:26
中学者
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:20
帖 子:3554
专家分:80
注 册:2007-9-14
收藏
得分:0 
优化常数因子可达到(3/2)n次比较...和求最大最小数一样的做法~

樱花大战,  有爱.
2008-12-13 22:38
howacter
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2008-12-14
收藏
得分:0 
可以先求出最大的数,然后求比最大数小但比起他数大的数,即为第二大的数:
#include <stdio.h>
int main(void)
{
    int data[]={15,4,5,37,50,60,45,96,75,10};    //可以根据情况自己输
    int max,sec,i,j;
    max=data[0];
     for(i=1;i<10;i++)
     {
         if(max<data[i])    max=data[i];
         j=i;
     }
     sec=data[(j-1<0)?j+1:j-1];
    for(i=0;i<10;i++)
    {
        if(data[i]==max) continue;    //若有两个最大数则只算一个
        else if(sec<data[i]) sec=data[i];
    }
    printf("max=%d\n",max);
    printf("second=%d\n",sec);    
    getch();
    return 0;
}
2008-12-14 04:16
luqiongzhi
Rank: 1
等 级:新手上路
帖 子:16
专家分:0
注 册:2008-12-3
收藏
得分:0 
#include<stdio.h>
#define size 10
main()
{
int a[10],i,max,min;
printf("please input 8 integers:\n");
for(i=0;i<size;i++)
scanf("%d",&a[i]);
min=max=a[0];
for(i=1;i<size;i++)
{
 if(max<a[i]) max=a[i];
 if(min>a[i]) min=a[i];
 }
 printf("Maximum value is %d\n",max);
printf("Minmum value is %d\n",min);
}
2008-12-14 10:54
快速回复:找出10个数中最大的两个数,怎么编啊
数据加载中...
 
   



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

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