| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 663 人关注过本帖
标题:求高手解答一道编程题目
只看楼主 加入收藏
华子天空
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2011-6-1
收藏
 问题点数:0 回复次数:8 
求高手解答一道编程题目
输入8个整数  将其中最大的和最后一个交换,最小的和最后一个交换。
搜索更多相关主题的帖子: 最大的 
2011-06-01 13:38
oriontyy
Rank: 1
等 级:新手上路
帖 子:5
专家分:5
注 册:2011-5-31
收藏
得分:0 
什么意思。
2011-06-01 13:53
lhp3774848
Rank: 2
来 自:福建省
等 级:论坛游民
帖 子:46
专家分:77
注 册:2011-5-3
收藏
得分:0 
不懂
2011-06-01 13:57
KOF小渔
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2010-11-10
收藏
得分:0 
确实没听懂
2011-06-01 15:46
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:0 
【最大的和最后一个交换,最小的和最后一个交换。】 什么意思?

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-06-01 15:48
liangjinchao
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:376
专家分:697
注 册:2010-11-8
收藏
得分:0 
这样还有什么意思啊?

因为有了因为,所以有了所以,既然已成既然,何必再说何必
2011-06-01 18:09
lz1091914999
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:四川
等 级:贵宾
威 望:37
帖 子:2011
专家分:5959
注 册:2010-11-1
收藏
得分:0 
程序代码:
#include <stdio.h>

void swap(int * p1, int * p2) {
    if(p1 == p2)
        return;
    *p1 ^= *p2;
    *p2 ^= *p1;
    *p1 ^= *p2;
}

int main(void) {
    int max_index, min_index, i, numbers[8];
    for(i = 0; i < 8; i++)
        scanf("%d", numbers + i);
    max_index = 0;
    min_index = 0;
    for(i = 1; i < 8; i++) {
        if(numbers[max_index] < numbers[i]) {
            max_index = i;
        }
        if(numbers[min_index] > numbers[i]) {
            min_index = i;
        }
    }
    swap(numbers + max_index, numbers + 7);
    swap(numbers + min_index, numbers + 7);
    for(i = 0; i < 8; i++)
        printf("%-4d", numbers[i]);
    puts("");
    return 0;
}
图片附件: 游客没有浏览图片的权限,请 登录注册



My life is brilliant
2011-06-01 18:55
华子天空
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2011-6-1
收藏
得分:0 
#include<stdio.h>
main()
{
    int a[8],i,*p,max,min,t;
      max=min=0;
      p=a;
      for(i=0;i<8;i++)
          scanf("%d",&a[i]);
      for(i=0;i<8;i++)
          if(*(p+i)<*(p+min))
              min=i;
          if(min!=7)
          {t=*(p+7);
          *(p+7)=*(p+min);
          *(p+min)=t;
          }
          for(i=0;i<8;i++)
              if(*(p+i)>*(p+max))
                  max=i;
              if(max!=0)
              {t=*(p+0);
              *(p+0)=*(p+max);
              *(p+max)=t;
              }
              for(p=a;p<a+8;p++)
                  printf("%d\n",*p);
}
2011-06-02 13:41
华子天空
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2011-6-1
收藏
得分:0 
这个可以吗?
2011-06-02 13:41
快速回复:求高手解答一道编程题目
数据加载中...
 
   



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

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