一、快速排序(快速分类)算法:

问题描述:给定线性集中n个元素和一个整数k,1<=k<=n,要求找出这n个元素中第k小的元素。

思想:选取数组A中的某个元素 t=A[s],然后将其他元素重新排列,使A中所有在t以前出现的元素都小于或等于t,而在t之后出现的元素都大于或等于t。这个重新整理的过程称为划分,t称为划分元素。

方法:分治法

算法(SPARKS):

 c++实现:

 #include<iostream>
 #include<cstdlib>
 #include<ctime>
 using namespace std;
 /*
 @快序排列算法的实现
 */
 int partition(int data[],int m,int p)///返回p,使得data[p]是第p小的值
 {
     int i=m,j=data[i];///j是划分元素
     bool flag=true;
     while(flag)
     {
         do
             i++;
         while(data[i]<j);
         do
             p--;
         while(data[p]>j);
         if(i<p)
         {
             int temp;
             temp=data[i];
             data[i]=data[p];
             data[p]=temp;
         }
         else
             flag=false;
     }
     data[m]=data[p];
     data[p]=j;
     return p;
 }
 void quicksort(int data[],int low,int high)
 {
     if(low<high)
     {
         ;
         temp=partition(data,low,temp);
         quicksort(data,low,temp-);
         quicksort(data,temp+,high);
     }
 }
 int main()
 {
 /*
 @产生一个规模为CNT的,范围为[RANDMIN,RANDMAX)的随机数组,并显示
 */
     int cnt,randmin,randmax;
     cout<<"Please Input 'CNT' 'RANDMIN' 'RANDMAX'"<<endl;
     cin>>cnt>>randmin>>randmax;
     const int CNT=cnt,
               RANDMIN=randmin,
               RANDMAX=randmax;
     int Data[CNT];
     srand((unsigned)time(NULL));
     ; i<CNT; i++)
         Data[i]=RANDMIN+rand()%(RANDMAX-RANDMIN);
     cout<<"Before Change,Data="<<endl;
     ; i<CNT; i++)
         cout<<Data[i]<<"    ";
     cout<<endl;
 /*
 @将数组用快速排序算法排序,并显示
 */
     quicksort(Data,,CNT-);
     cout<<"After Change,Data="<<endl;
     ; i<CNT; i++)
         cout<<Data[i]<<"    ";
     cout<<endl;
     ;
 }

算法分析:

最坏时间复杂度:O(n2)

平均时间复杂度:O(nlogn)

空间复杂度:O(n)[可通过有递归转变为迭代,达到O(logn)]

稳定度:不稳定

二、选择问题

问题描述:给定线性集中n个元素和一个整数k,1<=k<=n,要求找出这n个元素中第k小的元素。

思想:借助快速排序中的一次分划操作实现。

方法:二次取中法(分治法)

算法(SPARKS):

c++实现:

 #include<iostream>
 #define BIG 1024;
 using namespace std;
 ;
 ] {,,,,,,,,,,};
 int partition(int m,int p)///返回p,使得data[p]是第p小的值
 {
     int i=m,j=A[i];///j是划分元素
     bool flag=true;
     while(flag)
     {
         do
             i++;
         while(A[i]<j);
         do
             p--;
         while(A[p]>j);
         if(i<p)
         {
             int temp;
             temp=A[i];
             A[i]=A[p];
             A[p]=temp;
         }
         else
             flag=false;
     }
     A[m]=A[p];
     A[p]=j;
     return p;
 }
 int select(int k)
 {
     int m,r,j;
     m=;
     r=n;
     A[n]=BIG;
     bool flag=true;
     while(flag)
     {
         j=r;
         j=partition(m,j);
         if(k==j)
             flag=false;
         else if(k<j)
             r=j;
         else
             m=j+;
     }
     return A[j];
 }
 int main()
 {

     cout<<"Before Change,A="<<endl;
     ; i<n; i++)
         cout<<A[i]<<"    ";
     cout<<endl;
     cout<<"Please Input Your Choice(1-10)"<<endl;
     int s;
     cin>>s;
     cout<<"Your Choice: ";
     cout<<)<<endl;
     cout<<"After Change,A="<<endl;
     ; i<n; i++)
         cout<<A[i]<<"    ";
     cout<<endl;
 }

算法分析:

在最坏情况下,算法Select需要O(n2)计算时间
但可以证明,算法Select可以在O(n)平均时间内找出n个输入元素中的第k小元素。

一个快速排序(分类)及使用类似思想实现选择问题[c++实现]的更多相关文章

  1. 做一个logitic分类之鸢尾花数据集的分类

    做一个logitic分类之鸢尾花数据集的分类 Iris 鸢尾花数据集是一个经典数据集,在统计学习和机器学习领域都经常被用作示例.数据集内包含 3 类共 150 条记录,每类各 50 个数据,每条记录都 ...

  2. fastText、TextCNN、TextRNN……这里有一套NLP文本分类深度学习方法库供你选择

    https://mp.weixin.qq.com/s/_xILvfEMx3URcB-5C8vfTw 这个库的目的是探索用深度学习进行NLP文本分类的方法. 它具有文本分类的各种基准模型,还支持多标签分 ...

  3. 用 Java 实现一个快速排序算法

           快速排序是排序算法中效率最高的一种,它是利用递归的原理,把数组无限制的分成两个部分,直到所有数据都排好序为止. 快速排序是对冒泡排序的一种改进.它的基本思想是通过一趟排序将要排序的数据分 ...

  4. 用UWP实现一个和win10设置页面类似的布局

    不知道有人注意过Win10中的设置页面的布局没?那个页面会根据不同的窗口宽度来调节显示的内容,甚至来后退按钮的操作在不同的宽度也是不同的,看图: 是不是有点cool呢,这篇文章,我们就来做一个类似的布 ...

  5. magento的robots文件编写和判断是否是一个导航分类页面

    magento是网店系统,我们突出的是我们的产品,所以,有很多路径我们不想让搜索引擎索引到,所以我们需要用robots文件进行限制 下面是麦神magento的robots.txt里面的内容,因为很多u ...

  6. 转:一个C语言实现的类似协程库(StateThreads)

    http://blog.csdn.net/win_lin/article/details/8242653 译文在后面. State Threads for Internet Applications ...

  7. linq to sql用partial扩展属性,创建一个部分类(用于多表连接)

    1.在窗体中创建dataGridView显示表: using System; using System.Collections.Generic; using System.ComponentModel ...

  8. java算法面试题:设计一个快速排序。双路快速排序,简单易于理解。

    package com.swift; import java.util.ArrayList; import java.util.Collections; import java.util.Compar ...

  9. matlab使用libsvm入门教程——使用matlab安装配置libsvm以及一个svm分类实例

    前言 此教程专注于刚入门的小白, 且博客拥有时效性, 发布于2019年3月份, 可能后面的读者会发现一些问题, 欢迎底下评论出现的问题,我将尽可能更新解决方案. 我开始也在如何安装libsvm上出现了 ...

随机推荐

  1. 搭建Apache Web服务器

    1.下载Apache服务器的安装包 地址:http://httpd.apache.org/download.cgi 从http://archive.apache.org/dist/httpd/bina ...

  2. 【Android接百度地图API】百度地图Demo点击按钮闪退

    运行百度地图自带的BaiduMap_AndroidSDK_v4.1.0_Sample里面的BaiduMapsApiASDemo发现点击上面的按钮会闪退,控制台报的是xml的问题 查了一下,官方文档特别 ...

  3. C++中有关数组的相关问题

    1.数组长度相关: strlen(from <string.h>)只是针对字符数组才有的,他不包含\0的长度.无法对其他类型求长度.sizeof()则可以对\0发起作用.记住(a.leng ...

  4. jdbc链接数据库的三种方式

    /** * jdbc连接数据库 * @author APPle * */ public class Demo1 { //连接数据库的URL private String url = "jdb ...

  5. python之路十五

    CSS position 属性 定义和用法position 属性规定元素的定位类型.说明这个属性定义建立元素布局所用的定位机制.任何元素都可以定位,不过绝对或固定元素会生成一个块级框,而不论该元素本身 ...

  6. Visual Studio 常用快捷键备忘

    在代码中插入书签 用途 操作   vs2013 快速在自定义的不同代码位置跳转 首先点击: 编辑=>书签=>启用书签 然后再在代码编辑窗口 ctrl+k, k (取消书签,再按一次 ctr ...

  7. CAD打印线条太粗、线条颜色设置

    不管你是使用打印机,还是将CAD转换为PDF文件,如果出现以下情况,线条太粗,根本看不清楚,怎么解决呢? 或者,不想通过图层复杂.繁琐的设置,想将各种颜色线条的CAD全部打印成黑白,或者指定某一种颜色 ...

  8. 什么时候用Model,什么时候用Entity?

    在建立一个实体类的时候,究竟是用Model还是用Entity?比如MVC中,Model存了数据实体,但是他被称为Model,而在EF中,Entity也是存放数据实体,却被称作Entity,这两者有何区 ...

  9. js识别当前用户设备的几个方法

    公司要做一个APP下载页面,里面需要判断是安卓还是苹果访问本页面,最开始想偷懒直接在给IOSAPP返回IOSAPP商店地址,然后Android直接进行访问.但想着毕竟做两个页面不利于后期维护和修改,打 ...

  10. VC++ GetModuleFileName()获取路径字符串中带波浪线~

    GetModuleFileName()获取的字符串中带波浪线,不是完整的路径显示. 原因:获取的是短路径,进行了缩写 解决:还原长路径 TCHAR }; GetLongPathName( strTem ...