标题:排序算法求助
只看楼主
trust
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2006-8-23
 问题点数:0 回复次数:6 
排序算法求助
一无序数组 求一最简算法使负数排在前,正数在负数之后
搜索更多相关主题的帖子: 算法 正数 负数 
2006-08-23 09:02
trust
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2006-8-23
得分:0 

#include"iostream.h"
void main()
{
int a[]={3,2,1,-5,-9,5,-8};
int n=sizeof(a);
for(int i=0;i<n;i++)
cout<<*(a+i)<<" ";
cout<<endl;
int k=0,temp;
while(k<n)
{
if(*(a+k))
{
temp=a[n-1];
a[n-1]=a[k];
for(int i=k;i<n-1;i++)
{
a[i]=a[i+1];
}
}
k++;
}
for(int j=0;j<n;j++)
cout<<a[j]<<" ";

}
我的算法 不知道错在哪里

2006-08-23 09:05
yeshirow
Rank: 4
等 级:贵宾
威 望:10
帖 子:854
专家分:0
注 册:2006-6-8
得分:0 

n = sizeof(a)

n = sizeof(a) / sizeof(int)


原來朋友仔感情再天真, 亦是我永遠也會愛惜的人, 明日愛他人, 也記住學會不要緊; 原來朋友比戀人更高分, 亦讓我開始懂得不記恨, 若大家都敏感, 我更要永遠記得拒絕再因小事怪人, 爲何沒有這條校訓...Twins-朋友仔 MCSD Training
2006-08-23 09:25
maoguoqing
Rank: 6Rank: 6
来 自:重庆
等 级:贵宾
威 望:28
帖 子:2980
专家分:19
注 册:2005-12-5
得分:0 
将这句int n=sizeof(a);改成int n=sizeof(a)/4;试试..

天行健,君子以自强不息!!QQ:68660681
2006-08-23 09:28
trust
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2006-8-23
得分:0 
谢谢两位 但好像还有错误
还有没有好一点的算法 各位大哥帮帮忙
2006-08-23 12:37
yeshirow
Rank: 4
等 级:贵宾
威 望:10
帖 子:854
专家分:0
注 册:2006-6-8
得分:0 

sizeof(a) / sizeof(int)
與 sizeof(a) / 4 還是有分別的,
系統不同, int 的大小可能會不同.
-----------------------------------------------

沒有考慮過排序的演算法問題, 論壇中有不少這樣的例子了, 不妨找下.


原來朋友仔感情再天真, 亦是我永遠也會愛惜的人, 明日愛他人, 也記住學會不要緊; 原來朋友比戀人更高分, 亦讓我開始懂得不記恨, 若大家都敏感, 我更要永遠記得拒絕再因小事怪人, 爲何沒有這條校訓...Twins-朋友仔 MCSD Training
2006-08-23 12:47
myajax95
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:30
帖 子:2978
专家分:0
注 册:2006-3-5
得分:0 

template<class T>
T* partition(T* tStart, T* tEnd)
{
T tX = 0, *tLeft = tStart, *tRight = tEnd;
while (1)
{
while (!(*tRight < tX || tRight == tLeft))
tRight --;
while (*tLeft < tX && tLeft != tRight)
tLeft ++;

if (tLeft < tRight)
swap(*tLeft, *tRight);
else
return tRight;
}
}


http://myajax95./
2006-08-24 14:47



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




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

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