| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 614 人关注过本帖
标题:一个缠绕了我前年怒火的问题,请各位帮忙降降温!先谢过!
取消只看楼主 加入收藏
源本英明C
Rank: 3Rank: 3
来 自:日本
等 级:论坛游侠
帖 子:113
专家分:154
注 册:2010-5-14
结帖率:85.71%
收藏
已结贴  问题点数:20 回复次数:3 
一个缠绕了我前年怒火的问题,请各位帮忙降降温!先谢过!
题目:输入十个整数,将其中最小的数与第一个数对换,把最大的数和最后一个数对换。
#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
源本英明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
源本英明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.049893 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved