标题:输入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
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册: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



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-459528-1-1.html




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

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