| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 659 人关注过本帖
标题:输入10个整数,把其中最小的数与第一个数交换,最大的数与最后一个数交换。 ...
只看楼主 加入收藏
涧边幽草
Rank: 2
等 级:论坛游民
帖 子:37
专家分:15
注 册:2015-11-4
结帖率:88.89%
收藏
已结贴  问题点数:20 回复次数:1 
输入10个整数,把其中最小的数与第一个数交换,最大的数与最后一个数交换。请帮忙看看我这用指针来交换错哪里,为何会有如下图的结果
#include <stdio.h>
void input(int a[])
{
    int i;
    for(i=0;i<10;i++)  scanf("%d",&a[i]);
}
void swap(int a[])
{
    int *p,*q,i,temp1,temp2;
    p=a;q=a;
    for(i=0;i<10;i++)
    {
        if(*p<a[i]) p=a+i;
        if(*q>a[i]) q=a+i;
    }
    temp1=a[9];
    a[9]=*p;
    *p=temp1;
    temp2=a[0];
    a[0]=*q;
    *q=temp2;
}

void display(int a[])
{
    int i;
    for(i=0; i<10; i++)
        printf("%d\n", a[i]);
}
int main()
{
    int a[10];
    input(a);
    printf("input done\n");
    swap(a);
    printf("swap done\n");
    display(a);
    printf("display done\n");
    return 0;
}

图片附件: 游客没有浏览图片的权限,请 登录注册
搜索更多相关主题的帖子: 最大的 include display 
2015-11-23 23:04
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9024
专家分:54030
注 册:2011-1-18
收藏
得分:20 
第一步,找到最大值所在位置 和 最小值所在位置,没错
2, 1, 3, 4, 5, 6, 7, 8, 9, 0
                        p  q

第二步,当将最大值和最后一位交换时,最小值的位置已经变了
2, 1, 3, 4, 5, 6, 7, 8, 0, 9
                        p  q
你看,此时q指向的不再是最小值的位置
2015-11-24 08:39
快速回复:输入10个整数,把其中最小的数与第一个数交换,最大的数与最后一个数交 ...
数据加载中...
 
   



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

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