| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 614 人关注过本帖
标题:一个缠绕了我前年怒火的问题,请各位帮忙降降温!先谢过!
只看楼主 加入收藏
源本英明C
Rank: 3Rank: 3
来 自:日本
等 级:论坛游侠
帖 子:113
专家分:154
注 册:2010-5-14
结帖率:85.71%
收藏
已结贴  问题点数:20 回复次数:6 
一个缠绕了我前年怒火的问题,请各位帮忙降降温!先谢过!
题目:输入十个整数,将其中最小的数与第一个数对换,把最大的数和最后一个数对换。
#include<stdio.h>
int f(int x[],int n)
{
 int i,j,k,v,*p,*q;
 j=k=x[0];
 for(i=0;i<n;i++)
 {
 if(k<x[i])
  {k=x[i];p=&k;}
 else if(j>x[i])
  {j=x[i];q=&j;}
 }
 v=x[n-1];x[n-1]=*p;*p=v;
 v=x[0];x[0]=*q;*q=v;
 printf("%d ,%d\n",x[0],x[n-1]);
}
main()
{
int i,array[10];
printf("\nplease input the array:\n");
for(i=0;i<10;i++)
scanf("%d",&array[i]);
printf("the array after deal:\n");
f(array,10);
for(i=0;i<10;i++)
printf("%4d",array[i]);
getch();
}
程序貌似没有错误,但是结果却令我大吃一惊!
输出结果如下,输入十个数字:5 2 8 4 6 9 3 0 7 1
输出最大最小值:0,9
处理后的数字序列为:0 2 8 4 6 9 3 0 7 9。最大数和最小数输出了两次,第一个数和最后一个数被最大最小数覆盖,并没有在数列中输出,这是为何,我的程序中哪里出了问题,请大家指教,不胜感激,谢谢!
搜索更多相关主题的帖子: 怒火 各位 降温 缠绕 问题 
2010-06-07 13:55
myhnuhai
Rank: 10Rank: 10Rank: 10
等 级:青峰侠
威 望:3
帖 子:425
专家分:1725
注 册:2010-3-17
收藏
得分:5 
#include<stdio.h>
int f(int x[],int n)
{
int i,j,k,v,*p,*q;
j=k=x[0];
for(i=0;i<n;i++)
{
if(k<x[i])
  {k=x[i];p=&k;}
else if(j>x[i])
  {j=x[i];q=&j;}
}
v=x[n-1];x[n-1]=*p;*p=v;//你这里的赋值没有起到你想要的结果,你把v的值赋值给指针变量*p,只能说明指针变量现在指向了v,而不是把x[n-1]的值回传到*p原来指向的哪里去的!
v=x[0];x[0]=*q;*q=v;
printf("%d ,%d\n",x[0],x[n-1]);
}
main()
{
int i,array[10];
printf("\nplease input the array:\n");
for(i=0;i<10;i++)
scanf("%d",&array[i]);
printf("the array after deal:\n");
f(array,10);
for(i=0;i<10;i++)
printf("%4d",array[i]);
getch();
}




还是用普通变量编写吧
#include<stdio.h>
int f(int x[],int n)
{
    int i,j,k,v,m,p,q;
    j=k=x[0];
    for(i=1;i<n;i++)
    {
        if(k<x[i])
        {
              k=x[i];p=i;
        }
        else if(j>x[i])
          {
                  j=x[i];q=i;
          }
    }
   
v=x[n-1];x[n-1]=k;x[p]=v;
m=x[0];x[0]=j;x[q]=m
;
printf("%d ,%d\n",x[0],x[n-1]);
return 0;
}
main()
{
        int i,array[10];
        printf("\nplease input the array:\n");
        for(i=0;i<10;i++)
        scanf("%d",&array[i]);
        printf("the array after deal:\n");
        f(array,10);
        for(i=0;i<10;i++)
        printf("%4d",array[i]);
}

不要让肮脏的记忆,迷失了原本纯洁的心灵!
2010-06-07 14:41
a392271275
Rank: 2
等 级:论坛游民
帖 子:12
专家分:32
注 册:2010-5-17
收藏
得分:10 
#include<stdio.h>
int f(int x[],int n)
{
int i,j,k,v,*p,*q;
j=k=x[0];
for(i=0;i<n;i++)
{
if(k<x[i])
  {k=x[i];p=&x[i];} /*这里 你应该记录的是比x[0]的地址,照你原来这么写永远记录的是x[0]的地址 */
else if(j>x[i])
  {j=x[i];q=&x[i];}/*这里同上! */

}
v=x[9];x[9]=*p;*p=v;
v=x[0];x[0]=*q;*q=v;
printf("%d ,%d\n",x[0],x[n-1]);
}
main()
{
int i,array[10];
printf("\nplease input the array:\n");
for(i=0;i<10;i++)
scanf("%d",&array[i]);
printf("the array after deal:\n");
f(array,10);
for(i=0;i<10;i++)
printf("%4d",array[i]);
getch();
}


[ 本帖最后由 a392271275 于 2010-6-7 14:46 编辑 ]
2010-06-07 14:44
源本英明C
Rank: 3Rank: 3
来 自:日本
等 级:论坛游侠
帖 子:113
专家分:154
注 册:2010-5-14
收藏
得分:0 
回复 楼主 源本英明C
兄台,很感谢你的指点,但是回去调试了一下,你给的结果和我之前的结果是一致的,都存在我原来存在的问题。希望你再好好看看!

柔术:打败对手的最好方法就是心狠手辣,因为对手不会给你太多机会,如果他够厉害!
2010-06-07 15:10
源本英明C
Rank: 3Rank: 3
来 自:日本
等 级:论坛游侠
帖 子:113
专家分:154
注 册:2010-5-14
收藏
得分:0 
回复 2楼 myhnuhai
谢谢3楼的指点,问题已解决。我在指针这块很薄弱,请问阁下能给个学习的地址或者资料吗?谢过!

柔术:打败对手的最好方法就是心狠手辣,因为对手不会给你太多机会,如果他够厉害!
2010-06-07 15:14
a392271275
Rank: 2
等 级:论坛游民
帖 子:12
专家分:32
注 册:2010-5-17
收藏
得分:5 
回复 5楼 源本英明C
我一开始对指针也非常不理解
后来我们开了汇编课
对指针就有很直观的理解了
可以看下汇编方面的书籍
推荐 王爽老师所著的《汇编语言(第2版)》
2010-06-08 21:44
源本英明C
Rank: 3Rank: 3
来 自:日本
等 级:论坛游侠
帖 子:113
专家分:154
注 册:2010-5-14
收藏
得分:0 
回复 6楼 a392271275
感谢!

柔术:打败对手的最好方法就是心狠手辣,因为对手不会给你太多机会,如果他够厉害!
2010-06-09 15:15
快速回复:一个缠绕了我前年怒火的问题,请各位帮忙降降温!先谢过!
数据加载中...
 
   



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

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