一、排序

1.快速排序在下列哪种情况下最易发挥其长处?

答案是:

被排序的数据完全无序。

在数据基本有序的情况下,会退化为冒泡排序,复杂度会退化为O(n^2)。

[因为,如果是基本有序的话, 那么每次选取pivot,那么就会将序列分为两个长度相差很大的序列,比如1和n-1个,这样复杂度就会变成O(n^2),就是冒泡排序了]

[最好的情况就是分称平均得两份,那么复杂度是O(nlogn)]。

 为什么呢?

//快速排序的思想都忘了,到底是i和j互换吗?代码实现也不怎么会写,是递归调用吗?(是递归调用)

转自:https://www.cnblogs.com/surgewong/p/3381438.html

选取两个指向,一个是i从前向后,一个是j从后往前,i呢是越过所有小于pivot的元素(遇到等于pivot的不停),j呢越过所有不小于pivot的元素(对于等于pivot的元素不停,对它们i已经负责交换了,j就不必负责相等值得交换),通过这样可以消除逆序,而且分为更短的序列,序列之间不会再进行比较,减少了比较次数。

 ②还有非常重要的一点就是:快速排序使用递归调用需要栈,如果是序列平均分的话,那么递归最大深度就是O(logn),如果是按照非常不平均1和n-1那么最大调用深度就是O(n)。

:快速排序在排序过程中是根据基数值来进行比较,并不是进行相邻元素的比较,所以是一种不稳定的排序。

#include <iostream>

using namespace std;
int a[]={ , , , , ,};
void qs(int f,int t){
int pivot=f;
int i=f,j=t;
while(i<=j){//那么在这又产生了一个疑问,到底快排是稳定还是不稳定的呢?
while(j>a[pivot]&&j>i){
j--;
}
while(i<=a[pivot]&&i<j){
i++;
} }
} int main(){
//手动实现快排,加深印象。 //int pivot=0;
qs(,);
return ;
}

My laji Code

//这个代码太厉害了!

#include <stdio.h>

#define MAX_NUM 80

void quicksort(int* a, int p,int q)
{
int i = p;
int j = q;
int temp = a[p]; while(i < j)//不用=,那样自己和自己交换也没意思,应该也不会产生这样吧。
{
// 越过不小于基准值的数据
while( a[j] >= temp && j > i ) j--; if( j > i )
{
a[i] = a[j];//是这样赋值,而不是交换。
i++;//赋值完了之后,忘后移动一个。 // 越过小于基准值的数据
while(a[i] <= temp && i < j ) i++;//这个时候i再往前走。
if( i < j )
{
a[j] = a[i];
j--;//赋值完了之后,往前移动一个。
}
}
}
a[i] = temp;//这里i被赋值为temp。 for(int k = p; k <= q;k++)//这个主要就是打印一下序列。
{
if( k == i )
{
printf("(%d) ",a[k]);
continue;
}
printf("%d ",a[k]);
}
printf("\n"); if( p < (i-)) quicksort(a,p,i-);//递归调用。
if((j+) < q ) quicksort(a,j+,q);
} int main(int argc, char* argv[])
{
int a[MAX_NUM];
int n; printf("Input total numbers: ");
scanf("%d",&n); if( n > MAX_NUM ) n = MAX_NUM; for(int i = ; i < n;i++)
{
scanf("%d",&a[i]);
} printf("Divide sequence:\n");
quicksort(a,,n-); printf("The sorted result:\n");
for(int i = ; i < n;i++)
{
printf("%d ",a[i]);
}
printf("\n"); return ;
}

运行结果:

2.下面的排序方法中,关键字比较次数与记录的初始排列无关的是_

无关是什么意思呢?就是在最好最坏平均情况下它的复杂度都不变的。

那么从图中可以看出,是直接选择排序,堆排序,归并排序与初始状态无关。//这个图要多背几遍啊!

 3.个数约为 50k 的数列需要从小到大排序, 数列特征是基本逆序 (多数数字从大到小,个别乱序) ,以下哪种排序算法在事先不了解数列特征的情况下性能大概率最优(不考虑空间限制)___.

堆排序。

专项训练错题整理-nowcoder-算法的更多相关文章

  1. 专项训练知识点与错题整理-nowcoder-c++

    1- 来自:http://www.cskaoyan.com/thread-595813-1-1.html 1.拷贝构造函数 转自:https://www.cnblogs.com/alantu2018/ ...

  2. JSP前三章错题整理

    A: B: C: D:  web-inf目录中的文件不能被客户端直接访问. 正确答案是 C 您回答的是 D 回答错误 试题分析纠错设为收藏 (选择一项) 14 A: B: C: Tomcat作为Web ...

  3. java的错题整理

    为了阅读方便,我们写代码时要缩进,以便于更好的理解代码 对象是是具有相同属性和共同行为的一组类的实例,不是集合. B是标准格式,D没有对象接收它,所以这样子. boolean的默认值是false如果一 ...

  4. 初识waindows窗体程序错题整理

    解析:A:Items表示集合B:获取或设置 ComboBox 的可编辑部分中选定的文本.C:SelectedIndex是索引D:获取或设置 控件中选定项的模板 解析:本题目考不同窗体之间跳转的方法,使 ...

  5. python错题整理

    1.列表list去重 l1 = [1,1,2,3,5,5,4,4,4,5,6] set1 = set(l1) # print(set1) # set是集合 l2 = list(set1) # 将集合转 ...

  6. 错题集锦(二) -- Java专项

    错题集锦(二) -- Java专项 标签(空格分隔): 找工作 JVM的内存模型 线程共享: 堆(Heap):主要存放一些对象实例 方法区(Method Area / Non-Heap):用于存储已被 ...

  7. 谷歌大规模机器学习:模型训练、特征工程和算法选择 (32PPT下载)

    本文转自:http://mp.weixin.qq.com/s/Xe3g2OSkE3BpIC2wdt5J-A 谷歌大规模机器学习:模型训练.特征工程和算法选择 (32PPT下载) 2017-01-26  ...

  8. Bug是一种财富-------研发同学的错题集、测试同学的遗漏用例集

    此文已由作者王晓明授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 各位看官,可能看到标题的你一定认为这是一篇涉嫌"炒作"的文章,亦或是为了吸引眼球而起的标 ...

  9. 计算机二级C语言选择题错题知识点记录。

    计算机二级C语言选择题错题知识点记录. 1,在数据流图中,用标有名字的箭头表示数据流.在程序流程图中,用标有名字的箭头表示控制流. 2,结构化程序设计的基本原则:自顶向下,逐步求精,模块化,限制使用g ...

随机推荐

  1. android jni log

    在编写的jni时,经常需要输出打印信息进行调试,而C中printf在jni中没有效果,这时就需要使用NDK提供的函数. 1. jni中包含头文件 #include <android/log.h& ...

  2. mysql -- 预处理语句

    所谓预处理,即在真正执行某条SQL语句之前,先将SQL语句准备好,在执行过程中再绑定数据 语法: 准备预处理 prepare 预处理名字 from ‘要执行的SQL语句’ 执行预处理 execute ...

  3. bootstrap基础学习七篇

    bootstrap图片 Bootstrap 提供了三个可对图片应用简单样式的 class: .img-rounded:添加 border-radius:6px 来获得图片圆角. .img-circle ...

  4. hdu 2809(状压dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2809 思路:简单的状压dp,看代码会更明白. #include<iostream> #in ...

  5. 剑指 offer set 20 打印出和为 s 的连续正序序列

    题目 100 可以由 9~16, 或者 18 ~ 22 组成 思路 1. 与 Leetcode Container With Most Water 有些类似, 依然是平移题目. 但这道更加复杂 2. ...

  6. poj_3628 动态规划

    题目大意 有N个数字,大小为a[i], 给定一个数S,用这N个数中的某些数加起来使得结果sum>= S,且sum-S最小,求该最小的sum-S值. 题目分析 题意中可知,这N个数字的和肯定大于S ...

  7. maven 基本框架搭建

    在平时的开发中还是在写blog时,在项目实例开始都会需要一遍一遍的介绍maven框架搭建,重复性的工作让我觉得烦恼,现在展现一下Java的核心思想“重复利用”,将这个重复性的描述提取出来一次性介绍,以 ...

  8. SharePoint PerformancePoint开发实例

    前言 由于工作的原因,有一段时间没有发新的随笔了,最近使用了SharePoint PerformancePoint做了一些报表,与大家分享经验. 本文完全原创,转载请说明出处,希望对大家有用. 阅读目 ...

  9. Java中break、continue、return语句的使用区别

    break.continue.return之间的区别与联系 在软件开发过程中,逻辑清晰是非常之重要的. 代码的规范也是非常重要的.往往细节决定成败.在编写代码的时候,一定要理解语言的作用以及使用的方法 ...

  10. Go语言 基本类型

    在内存中的形式 首先看一下在go中,一些基础类型在内存中是以什么形态存在的,如下图所示: 变量j的类型是int32, 而变量i的类型是int,两者不是同一个类型,所以赋值操作i=j是一种类型错误can ...