• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >编程问答 > 快速排序结果出错

快速排序结果出错

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-06-07

佚名通过本文主要向大家介绍了实时统计数据排序结果,定量计分排序结果,excel排序结果不对,塑料膜实验的排序结果,sql查询结果排序等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com
问题:快速排序结果出错
描述:

正确的快排:

void quick_sort( vector<int>& numbers, int begin, int end )
{
  if( begin >= end-1 )
    return;
   int k = partition( numbers, index, begin, end);
   quick_sort( numbers, index, begin, k);
   quick_sort( numbers, index, k+1, end );
}
int partition(vector<int>& numbers, int begin, int end)
{
    int pivot = numbers[begin];
    int i = begin;
    int j = end;
    while( i < j ){
        while( numbers[++i] < pivot && i < end );
        while( numbers[--j] > pivot && j > begin );

            if( i < j ){
                   int tmp = numbers[i ];
                   numbers[i] = numbers[j];
                   numbers[j] = tmp;
                }
       }
       numbers[begin] = numbers[j];
       numbers[j] = pivot;
       return j;
}

我自己写的partition函数有一点不同,就是i,j的初始值不同,内层的while循环也有相应的改变,我觉得没有什么不同,但是使用我的partition函数排序结果就是错误的,求教这是怎么回事?

下面是我的partition函数

int partition(vector<int>& numbers, vector<int>& index, int begin, int end)
{
    int pivot = numbers[begin];
    int i= begin+1;//这里
    int j = end-1;

    while( i < j ){
        while( numbers[i] < pivot && i <= end-1){
                    ++i;
                }

                while( numbers[j] > pivot && j > begin ){
                    --j;
                }

            if( i < j ){
                   int tmp = numbers[i ];
                   numbers[i] = numbers[j];
                   numbers[j] = tmp;
                }
       }
       numbers[begin] = numbers[j];
       numbers[j] = pivot;
       return j;
}

解决方案1:

int i= begin+1;//这里
int j = end-1;

while( i < j )

你这里循环的次数就变了啊


分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 快速排序结果出错

相关文章

  • 2017-06-07 如何使python2在使用中文的时候,不用加u前缀?
  • 2017-06-07 在浏览器中查看gitlog
  • 2017-06-07 Python的多线程是伪命题吗?
  • 2017-06-07 IIS域名跳转的问题
  • 2017-06-07 (python)如何复制Spyder中Variableexplorer中的array或者matrix到其他文件中?
  • 2017-06-07 python的正则表达式匹配如何找到所有匹配成功的部分(包括重叠的)
  • 2017-06-07 (golang)go该如何学习主要的应用场景是什么?
  • 2017-06-07 详解一下javascript中的比较
  • 2017-06-07 上传400KB以上图片需要10秒左右
  • 2017-06-07 ios断点续传的问题

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 邮箱地址无法更改?
    • javaweb服务器如何监听服务器上的sendmail接收到了邮件,或者sendmail收到邮件后能通知web应用
    • Django创建超级用户问题,急求助
    • 能不能设计针对确定数对的通用转换函数?
    • 正则表达式python正则表达式难题。
    • golang有没有比较好的即实现ibatis又实现了hibernate功能的ORM库?
    • ruby一道循环算法题:不同ID出现次数
    • 如何实现网页在线浏览pdfexcelword等文件?诸如百度文库,豆丁网那样
    • (shell)我有一个需求svn的需求
    • picklepython怎样用pickle保存类的实例?

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有