这是什么排序

mxway 2014-04-04 09:40:34
昨天下午公司代码评审,公司开发人员中大部分说这是冒泡排序。好吧,我承认我肤浅。只有我一人说是选择排序。都是神人呀。

for(i=0; i<count-1; i++)
{
for(j=i+1; j<count; j++)
{
ATTR_ask_obj_attrib(tmpArray[i], "CHECKNO", attrValue);
checkNo1 = atoi(attrValue);
ATTR_ask_obj_attrib(tmpArray[j], "CHECKNO", attrValue);
checkNo2 = atoi(attrValue);

if(checkNo1 > checkNo2)
{
objTag = tmpArray[i];
tmpArray[i] = tmpArray[j];
tmpArray[j] = objTag;
}
}
}
...全文
124 4 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
buyong 2014-04-04
  • 打赏
  • 举报
回复
反正是个复杂度为O(N2)的
小律律 2014-04-04
  • 打赏
  • 举报
回复
__phoenix 2014-04-04
  • 打赏
  • 举报
回复
lz坚信自己的看法吧
lm_whales 2014-04-04
  • 打赏
  • 举报
回复
这是混合型排序,既非冒泡,也非选择。 选择排序,选好了才交换,每轮选出一个最小元(最大元),若干次比较,一次交换,把最小元(最大元)放在合适的位置。 冒泡交换相邻两个元素,每次遇到逆序就交换。每次比较就接着交换,交换的是相邻元素。 这个排序,交换的不是相邻元素,所以不是冒泡,每次比较就交换,也不是选择。 恰好像这两种排序的混合体。

65,184

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧