| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 851 人关注过本帖
标题:新人求教,一个简单的排序问题,,不知道哪里出错了
只看楼主 加入收藏
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
快速回复:新人求教,一个简单的排序问题,,不知道哪里出错了
数据加载中...
 
   



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

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