| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 956 人关注过本帖
标题:在一批数中求最大、小数,并将最大 数与最小数互换位置。
只看楼主 加入收藏
ay2450
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2010-4-13
结帖率:71.43%
收藏
已结贴  问题点数:10 回复次数:9 
在一批数中求最大、小数,并将最大 数与最小数互换位置。

#include<stdio.h>
#define N 5
int main(){
    int a[N],max,min,pos_max,pos_min,j;
    printf("Enter the nmuber:");
    for(j=1;j<=N;j++)scanf("%d",&a[j]);
    min=max=a[0];
    pos_min=pos_max=0;
    for(j=1;j<=N;j++)
    {
    if(min<a[j]){min=a[j];pos_min=a[j];}
    if(max>a[j]){max=a[j];pos_max=a[j];}
    }
    a[pos_max]=min;
    a[pos_min]=max;
    for(j=1;j<=N;j++)
        printf("%d,%d",max,min);
    return 0;
}

怎么搞不出来。
搜索更多相关主题的帖子: 小数 位置 
2010-05-05 23:39
炫舞小子
该用户已被删除
收藏
得分:0 
提示: 作者被禁止或删除 内容自动屏蔽
2010-05-05 23:59
ay2450
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2010-4-13
收藏
得分:0 
回复 2楼 炫舞小子
怎么改才正确呢。望高手指点指点
2010-05-06 09:07
冥卫
Rank: 8Rank: 8
来 自:深山老林
等 级:蝙蝠侠
帖 子:280
专家分:772
注 册:2010-4-20
收藏
得分:0 
等待中
2010-05-06 09:20
NOMIPS
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:86
专家分:537
注 册:2010-3-31
收藏
得分:0 
int main(){
    int a[N],a_max,a_min,pos_max,pos_min,j;
    printf("Enter the nmuber:");
    for(j=0;j<N;j++)
        scanf("%d",&a[j]);
    a_min=a_max=a[0];
    pos_min=pos_max=0;
    for(j=1;j<N;j++)
    {
    if(a_min<a[j])
        {
         a_min=a[j];
         pos_min=j;
        }
    if(a_max>a[j])
       {
        a_max=a[j];
        pos_max=j;
        }
     }

    printf("max=%d,min=%d\n",a_max,a_min);
    a[pos_max]=a_min;
    a[pos_min]=a_max;
    for(j=0;j<N;j++)
        printf("%d ",a[j]);
    return 0;
}
2010-05-06 10:17
NOMIPS
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:86
专家分:537
注 册:2010-3-31
收藏
得分:5 
#include<stdio.h>
#define N 5
int main(){
    int a[N],a_max,a_min,pos_max,pos_min,j;
    printf("Enter the nmuber:");
    for(j=0;j<N;j++)
        scanf("%d",&a[j]);
    a_min=a_max=a[0];
    pos_min=pos_max=0;
    for(j=1;j<N;j++)
    {
    if(a_min<a[j])
        {
         a_min=a[j];
         pos_min=j;
        }
    if(a_max>a[j])
       {
        a_max=a[j];
        pos_max=j;
        }
     }

    printf("max=%d,min=%d\n",a_max,a_min);
    a[pos_max]=a_min;
    a[pos_min]=a_max;
    for(j=0;j<N;j++)
        printf("%d ",a[j]);
    return 0;
}
2010-05-06 10:19
炫舞小子
该用户已被删除
收藏
得分:0 
提示: 作者被禁止或删除 内容自动屏蔽
2010-05-06 14:46
ay2450
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2010-4-13
收藏
得分:0 
回复 6楼 NOMIPS
#include<stdio.h>
#define N 5
int main(){
    int a[N],max,min,pos_max,pos_min,j;
    printf("Enter the nmuber:");
    for(j=1;j<N;j++)scanf("%d",&a[j]);
    min=max=a[0];
    pos_min=pos_max=0;
    for(j=1;j<N;j++)
    {
    if(min<a[j]){min=a[j];pos_min=j;}
    if(max>a[j]){max=a[j];pos_max=j;}
    }
    printf("%d,%d,%d,%d",max,min,pos_max,pos_min);
    a[pos_max]=min;
    a[pos_min]=max;
    for(j=1;j<N;j++)
            printf("%d",a[j]);   
    return 0;
}

这样改为什么不行?都一样的呀。。
2010-05-06 15:44
NOMIPS
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:86
专家分:537
注 册:2010-3-31
收藏
得分:5 
for(j=1;j<N;j++)scanf("%d",&a[j]); // 数组的第一个元素的下标为0,你这样只输入了a[1]--a[N-1],输入都错了,后果可想而知...
for(j=1;j<N;j++) // 同理...
2010-05-06 21:59
ay2450
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2010-4-13
收藏
得分:0 
回复 9楼 NOMIPS
thanks
2010-05-07 09:07
快速回复:在一批数中求最大、小数,并将最大 数与最小数互换位置。
数据加载中...
 
   



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

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