复杂度和简单排序算法

时间复杂度

以一个排序(选择排序)操作举例

假设我有一个数组,我要找出其中的最小值放到0的位置上

那么

第一次我会遍历数组中N个数(在0位置处),找出最小的数交换到0位置【看了(寻址)N次,比较N次,一次交换】

第二次我会看遍历数组中N-1个数(在1位置处),找出最小的数交换到1位置【看了(寻址)N-1次,比较N-1次,一次交换】

第三次我会看遍历数组中N-2个数(在2位置处),找出最小的数交换到2位置【看了(寻址)N-2次,比较N-2次,一次交换】

以此类推,遍历的范围会缩小,数也按从小到大排好

总结一下:

一共看了N+(N-1)+(N-2)+(N-3)+...次(等差数列)

一共比了N+(N-1)+(N-2)+(N-3)+...次(等差数列)

一共换了N次

上述对常数的操作次数加起来可以写成:aN2+bN+C

那么时间复杂度就是在常数操作数量级的表达式(上式)中,最高次项的次数,例如上面这个排序的时间复杂度就是O(N2)

异或

结论:

1、0异或N对于N

2、N异或N对于0

3、满足交换、结合律

4、一批数要异或在一起,那么不论先后顺序,得到的结果是一样的

快速交换a、b的值

int a = 甲;int b = 乙;

那么只需

a = a⊕b;(a = 甲⊕乙,b = 乙)
b = a⊕b;(a = 甲⊕乙,b = 甲⊕乙⊕乙 = 甲)
a = a⊕b;(a = 甲⊕乙⊕甲 = 乙,b = 甲)

便可完成a、b交换(不用额外申请空间,前提是a、b指向两个不同的内存空间)

找奇偶数

问题描述:

在一个数组中

1、只有一个数出现奇数次,其余的出现偶次,把它找出来

2、有两个数出现奇数次,其余的出现偶次,把它找出来并且给出这两个数是什么

要求时间复杂度为O(N),空间复杂度为O(1)

思路:

1、第一种情况

准备一个数int eor = 0

用eor把数组从头异或到尾

假如数组是[a,b,c,...]

那么

eor = eor⊕a;
eor = eor⊕b;
eor = eor⊕c;
...

最后eor 就是出现次数为奇数的那个数

例如数组为[2,1,3,1,3,1,3,2,1]

用eor去异或,最后结果一定是3

因为上述数组在以后时无需考虑顺序,数组可看成

[1,1,1,1,2,2,3,3,3]

4个1异或完是0;

2个2异或完是0;

3个3异或完是它本身(3);

结束

2、第二种情况

设这两个出现奇数次的数是a和b,并且我们知道两者不等

准备一个数int eor = 0

用eor把数组从头异或到尾,那么最后eor = a⊕b

先跟所有的偶数次的异或得到0,然后跟奇数次的a异或得a,再跟奇数次的b异或剩个b,最后成了a⊕b

因为a不等于b,所以eor不等于0,所以eor一定在某一位上不等于0(为1)

假设eor是在第8位上不为0,那么a和b的第8位一定是不一样的

再准备一个变量eor2

只有当数组中某个数的第8位是0(或者1),才把这个数同eor2异或,那么最后eor2会等于a或b的其中一个

之后再用eor异或eor2就可以得到另一个数

tips:

怎么着某一位是指定数的数?(比如第8位是1)

这个问题可以归结成:提取出最右侧的1

假设

​ k:1010111100

​ k取反:010100011

k取反+1:010100100

k&k取反+1 = 000000100,提取得到最右侧的1

在位运算中,需要把一个数最右侧的1提取出来

只需将这个数和它自身取反后加1的结果做与运算即可

结束

【算法day1】复杂度和简单排序算法(1)的更多相关文章

  1. 简单排序算法 C++类实现

    简单排序算法: 冒泡排序 插入排序 选择排序 .h代码: // // SortClass.h // sort and selection // // Created by wasdns on 16/1 ...

  2. 简单排序算法设计(Java)

    总共有八种排序算法,还是慢慢看吧 1.简单排序算法 简单排序算法就是设置标兵,逐个比较数,然后查找插入位置,插入 public static void p(int[] a){ for(int i=0; ...

  3. 《算法4》2.1 - 选择排序算法(Selection Sort), Python实现

    选择排序算法(Selection Sort)是排序算法的一种初级算法.虽然比较简单,但是基础,理解了有助于后面学习更高深算法,勿以勿小而不为. 排序算法的语言描述: 给定一组物体,根据他们的某种可量化 ...

  4. Java数据结构和算法(三):常用排序算法与经典题型

    常用的八种排序算法 1.直接插入排序 我们经常会到这样一类排序问题:把新的数据插入到已经排好的数据列中.将第一个数和第二个数排序,然后构成一个有序序列将第三个数插入进去,构成一个新的有序序列.对第四个 ...

  5. JavaScript 数据结构与算法之美 - 十大经典排序算法汇总(图文并茂)

    1. 前言 算法为王. 想学好前端,先练好内功,内功不行,就算招式练的再花哨,终究成不了高手:只有内功深厚者,前端之路才会走得更远. 笔者写的 JavaScript 数据结构与算法之美 系列用的语言是 ...

  6. python实现简单排序算法

    算法 递归两个特点: 调用自身 有穷调用 计算规模越来越小,直至最后结束 用装饰器修饰一个递归函数时会出现问题,这个问题产生的原因是递归的函数也不停的使用装饰器.解决方法是,只让装饰器调用一次即可,那 ...

  7. 用javascript实现简单排序算法

    声明:本文为原创文章,如需转载,请注明来源WAxes,谢谢! 本文为楼主自己的学习记录文章,若有不当之处请斧正. 本文主要记录排序算法 [冒泡排序] 感觉这个是最简单的排序算法了.直接引用维基百科里的 ...

  8. js的几种简单排序算法及其效率实测

    function swap(arr,index1,index2){ var t = arr[index1]; arr[index1] = arr[index2]; arr[index2] = t; } ...

  9. 三种简单排序算法(java实现)

    一.冒泡排序 算法思想:遍历待排序的数组,每次遍历比较相邻的两个元素,如果他们的排列顺序错误就交换他们的位置,经过一趟排序后,最大的元素会浮置数组的末端.重复操                   作 ...

  10. [读书笔记]算法(Sedgewick著)·第二章.初级排序算法

    本章开始学习排序算法 1.初级排序算法 先从选择排序和插入排序这两个简单的算法开始学习排序算法.选择排序就是依次找到当前数组中最小的元素,将其和第一个元素交换位置,直到整个数组有序. public s ...

随机推荐

  1. [转帖]rsync参数详解

    最近经常需要传送文件,学习到rsync这个非常好用的工具.rsync的传输方不像是scp复制粘贴,而是是创建一个镜像,所以在传输效率上比scp命令要快很多,缺点就是对文件的属性如权限.用户.组.时间戳 ...

  2. [换帖]Linux命令之iconv命令

    一.命令简介   日常工作中我们需要将windows生成的文件上传到Linux系统,有时候会因为编码问题出现显示乱码.例如我上传了一个csv文件到Linux服务器上,默认编码为GB2312,在Linu ...

  3. css中也可以使用变量了?

    前言 大家都听说过变量,我们学习的任何语言都有变量的存在. css中是否也存在变量呢? 也许很多小伙伴也是通过less,scss中来使用css变量 其实在css中也是有变量的,今天我们也来学习一下. ...

  4. 程序员必备!10款实用便捷的Git可视化管理工具

    前言 俗话说得好"工欲善其事,必先利其器",合理的选择和使用可视化的管理工具可以降低技术入门和使用的门槛.我们在团队开发中统一某个开发工具的使用能够大大降低沟通成本,提高协作沟通效 ...

  5. 乌班图安装docker

    目录 一.前言 二.安装 2.1 设置仓库 2.3 安装 Docker Engine 2.4 安装特定版本的 Docker Engine: 2.5 测试 三.配置非 root 用户运行 Docker ...

  6. 自定义httpServletRequestWrapper导致上传文件请求参数丢失

    问题背景 项目是 SpringBoot 单体式,在项目中,为了实现调用 controller 请求的日志记录功能.因此做了以下配置: 创建自定义拦截器 LogInterceptor; 因为需要使用到流 ...

  7. Midjourney|文心一格prompt教程[技巧篇]:生成多样性、增加艺术风格、图片二次修改、渐进优化、权重、灯光设置等17个技巧等你来学

    Midjourney|文心一格prompt教程[技巧篇]:生成多样性.增加艺术风格.图片二次修改.渐进优化.权重.灯光设置等17个技巧等你来学 1.技巧一:临摹 我认为学习图片类的 prompt,跟学 ...

  8. MVC和WebAPI如何从Filter向Action中传递数据

    http://www.itfanr.cc/2016/04/17/transfer-data-from-filter-to-action/ MVC和WebAPI如何从Filter向Action中传递数据 ...

  9. centos环境下nginx1.19.7离线升级至1.22.1

    环境 centos7 nginx1.19.7 下载新版本nginx 下载地址:http://nginx.org/en/download.html 升级 先看一下原版本: 新安装包传至服务器,升级: # ...

  10. 目录:CH57x/CH58x/CH59x/CH32V208低功耗蓝牙应用

    外设相关: CH59x 系统16位PWM使用 - 小舟从此逝_1 - 博客园 (cnblogs.com) CH59X/CH58X/CH57X PWM使用 - 小舟从此逝_1 - 博客园 (cnblog ...