标题:新人求教,一个简单的排序问题,,不知道哪里出错了
只看楼主
hjx1120
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:李掌柜
等 级:贵宾
威 望:41
帖 子:1314
专家分:6927
注 册:2008-1-3
得分:0 
回复 10楼 林月儿
一条沙丁鱼  的才是<数据结构>里面的swap
2015-06-07 15:35
一个小灰机
Rank: 2
等 级:论坛游民
帖 子:17
专家分:33
注 册:2015-3-14
得分:0 
1、你的函数采用的值传递,在函数调用结束后,系统就释放内存了,所以两个值根本没有改变,你要想实现排序功能,可以用指针:
void swap(int *i, int *j);
主函数中swap(&a,&b);
2、你写的函数中的return(i,j);返回的时候只是返回i
2015-06-07 16:13
幻想乡流浪者
Rank: 2
来 自:种花家
等 级:论坛游民
帖 子:27
专家分:21
注 册:2015-6-6
得分:0 
第一:max只能返回一个值,所以return i;就OK了;
第二:按照你的想法,多半得到的只是最大值;
试着改了一下:
程序代码:
int i,j,k,t;
i=max(a,b);
j=max(b,c);
k=max(i,j);//k为最大值
if(i>j)
{
  t=i;
  i=j;
  j=t;
}
printf("%d,%d,%d",k,j,i);


没有调试过,你看一下行不行。
2015-06-09 02:11



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




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

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