算法设计与分析期末复习(一)

news2024/10/6 5:58:37

算法的定义和特征

  1. 什么是算法?
    算法是求解某一特定问题的一组有穷规则的集合,它是由若干条指令组成的有穷符号串。
  2. 算法的五个重要特性
    确定性:算法中每一条指令必须有确切的含义,不存在二义性。只有一个入口和一个出口。
    可行性:算法描述的操作可以通过已经实现的基本运算来执行有限次来实现。
    输入:一个算法有零个或多个输入。
    输出:一个算法有一个或多个输出。
    有穷性:一个算法必须在执行有穷步之后结束,且每一步都在有穷时间内完成。
  3. 算法设计的质量指标
    正确性,可读性,健壮性,效率与存储量

算法和程序的区别

算法的有穷性意味着不是所有的计算机程序都是算法

算法复杂性

算法复杂性=计算机所需要的计算机资源=时间复杂度+空间复杂度
一般只考虑三种情况下的时间复杂性:最坏情况、最好情况和平均情况的复杂性。
Tmax(n)、Tmin(n)和Tavg(n)

  1. 上界函数
    f(n) = O(g(n))
    若算法用n值不变的同一类数据在某台机器上运行,所用的时间总是小于|g(n)|的一个常数倍。所以g(n)是f(n)的一个上界函数。f(n)的增长最多像g(n)的增长那样快。
    求最小的g(n)
  2. 下界函数
    f(n) = Ω(g(n))
    若算法用n值不变的同一类数据在某台机器上运行,所用的时间总是不小于|g(n)|的一个常数倍。所以g(n)是f(n)的一个下界函数。f(n)的增长至少像g(n)的增长那样快。
    求最大的g(n)
  3. 平均情况限界函数
    f(n) = θ(g(n))

常见的多项式限界函数
Ο(1) < Ο(logn) < Ο(n) < Ο(nlogn) < Ο(n2) < Ο(n3)
常见的指数时间限界函数
O(2n) < O(n!) < O(nn)
当n取值较大时,指数时间算法和多项式时间算法在计算时间上非常悬殊。

最优算法
问题的计算时间下界为Ω(f(n)),则计算时间复杂性为O(f(n))的算法是最优算法。
排序问题的计算时间下界是Ω(nlogn),则计算时间复杂性为O(nlogn)的排序算法是最优算法。

递归

递归算法:直接或间接的调用自身的算法
递归函数:函数自身给出定义的函数

  1. 基于归纳法的递归
    Fibonacci数列
    无穷数列1,1,2,3,5,8,13,21,34,55,……,称为Fibonacci数列。
    可递归定义为:
    在这里插入图片描述
    第n个Fibonacci数计算:
int fibonacci(int n){
	if(n<=1){
		return 1;
	}else{
		return fibonacci(n-1)+fibonacci(n-2);
	}
}

优点:结构清晰,可读性强,而且容易用数学归纳法来证明算法的正确性,因此它为设计算法,调试程序带来很大方便。
缺点:递归算法的运行效率低,无论是耗费的计算时间还是占用的存储空间都比费递归算法高。
2. 基于分治法的递归

分治法

将一个难以直接解决的大问题,分割成一些规模较小的相同问题,以便各个击破,分而治之。

分治法所能解决的问题一般具有以下几个特征:

  1. 该问题的规模缩小到一定的程序就可以容易地解决
  2. 该问题可以分解为若干个规模较小的相同问题,即该问题具有最优子结构性质
  3. 利用该问题分解出的子问题的解可以合并为该问题的解。
  4. 该问题分解出的各个子问题是相互独立的,即子问题不包含公共的子问题。

分治法的基本步骤:

  1. 分解:将原问题分解为若干个规模较小,相互独立,与原问题形式相同的子问题。
  2. 解决:若子问题规模较小而容易地解决则直接解,否则递归地解各个子问题。
  3. 合并:将各个子问题的解合并为原问题的解。

分治法的复杂性分析——Master定理
分治法将规模为n的问题分解成k个规模为n/k的子问题。设分解阈值n=1,将原问题分解为k个子问题以及用merge将k个子问题的解合并成原问题的解需要f(n)个单位时间。
在这里插入图片描述
在这里插入图片描述

二分搜索

给定已按升序排好序的n个元素a[0:n-1],现在要从n个元素中找出一特定元素x

int binarySearch(int a[],int &x,int l,int r){
	while(l <= r){
		int mid = (l+r)/2;
		if(a[mid] == x){
			return mid;
		}else if(a[mid] < x){
			l = mid + 1;
		}else{
			r = mid - 1;
		}
	}
	return -1;
}

算法复杂性分析:
每次执行一次算法的while循环,待搜索数组的大小减少一半。
最坏情况下,执行O(logn)次。

合并排序

将待排序的元素分成大小大致相同的2个子集合,分别对2个子集合进行排序,最终将排好序的子集合合并成为所要求的排好序的集合。

void mergeSort(int a[],int l,int r){
	if(l < r){ //至少有两个元素
		int m = (l+r)/2;
		mergeSort(a,l,m);
		mergeSort(a,m+1,r);
		merge(a,b,left,m,r);//合并到数组b
		copy(a,b,l,r); //复制回数组a
	}
}

在这里插入图片描述

void qSort(int p,int r)
{
	if(p < r){
		int q = partition(p,r); //以a[p]为基准元素将a[p:r]划分成3段a[p:q-1],a[q]和a[q+1:r],下标q再划分过程中确定。
		qSort(p,q-1);
		qSort(q+1,r);
	}
}
int partition(int a[],int p,int r){
	int i = p;
	int j = r + 1;
	int x = a[p];
	while(true){
		while(a[--j] >= x);
		swap(a[i],a[j]);
		while(a[++i] <= x && i < r);
		if(i >= j){
			break;
		}
		swap(a[i],a[j]);
	}
	return j;
}

线性时间选择问题

问题描述:给定线性集中n个元素和一个整数k,要求找出n个元素中第k小的元素。当k=1时,找最小元素;k=n时,找最大的元素;k = (n+1)/2,找中位数。

int randSelect(int a[],int start,int end,int k){
	if(start == end) return A[start];
	int i = RandomizedPartition(A,start,end);
	int n = i - start + 1; //左子数组A[start:i]的元素个数
	if(k <= n){
		return randSelect(a,start,i,k);
	}else{
		return randSelect(a,i+1,end,k-n);
	}
}

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

真正的线性时间选择
将n个输入元素划分成n/5,每组5个元素,只可能有一个组不足五个元素。用任意一种排序算法,将每组中的元素排好序,并取出它们每组中的中位数,共n/5个。
递归调用Select找出这n/5个元素的中位数,如果个数是偶数,就选取较大的一个作为划分基准。

int Select(int a[], int start, int end, int k){
	if(end-start < 30){
		用某个简单排序算法对数组a[start:end]排序;
		return a[start+k-1];
	}
	for(int i = 0; i <= (end-start-4)/5; i++){
		将a[start+i*5]到a[start+i*5+4]的第3小元素与a[start+i]交换位置;
	}
	//找出中位数的中位数
	int x = Select(a,start,start+(end-start-4)/5,(end-start-4)/10);
	int i = partition(a,start,end,x);
	int n = i-start+1;
	if(k <= n){
		return Select(a,start,i,k);
	}else{
		return Select(a,i+1,end,k-n);
	}
}

在这里插入图片描述
n个元素的数组调用select()需要T(n)
找中位数的中位数需要T(n/5)
使用基准得到两个子数组分别最多有3n/4个元素

循环赛日程表问题

分治法策略:将所有的选手分为两半,n个选手的比赛日程表可以通过n/2个选手设计的比赛日程表决定。
递归地对选手进行分割,直到只剩下两个选手时,只要让这两个选手进行比赛就可以了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/81543.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

raft协议详解

文章目录1. 分布式系统数据一致性概述2. rafts算法基础2.1 基础2.2leader选举2.3raft算法数据同步2.4 raft算法之脑裂2.5 leader宕机处理raft 动画演示1. 分布式系统数据一致性概述 redis保证了可用性&#xff0c;牺牲了一致性 2. rafts算法基础 2.1 基础 2.2leader选举 2.3r…

Python列表(list)反序的7种方法

Python列表(list)原址反序的方法 (本文获得CSDN质量评分【x】)【学习的细节是欢悦的历程】Python 官网&#xff1a;https://www.python.org/ Free&#xff1a;大咖免费“圣经”教程《 python 完全自学教程》&#xff0c;不仅仅是基础那么简单…… 自学并不是什么神秘的东西&a…

第1章 Rust安装

Rust是一门安全的语言&#xff0c;最近也加入到Linux内核中&#xff0c;因此后续这门语言会越来越流行&#xff0c;所以准备学习下&#xff0c;本篇介绍Rust在Window平台上的安装过程。 目录 安装步骤 1.到官网下载安装包 2.搭建 Visual Studio Code 开发环境 安装步骤 1.…

webpack 简介以及为什么要用webpack

webpack 是什么 webpack 是一个用于现代JavaScript 应用程序的静态模块打包工具。 看来像是1个js的打包工具&#xff0c; 但是实际上并没有这么简单 传统html js 写法1 对于前端新手&#xff0c; 或者被逼写前端的后端开发&#xff0c; 他们写的代码很可能是这样的 html: &…

mysql高可用(MHA集群)

目录 一、MHA概述 &#xff08;1&#xff09;什么是MHA &#xff08;2&#xff09;MHA的组成 1&#xff09;MHA Node&#xff08;数据节点&#xff09; 2&#xff09;MHA Manager&#xff08;管理节点&#xff09; &#xff08;3&#xff09;MHA的特点 二、搭建mysql HMA…

软件体系结构复习文档

引言&#xff1a; 软件体系结构是大三下学期我们学的一门专业课&#xff0c;这门课学院给我们安排的是一名女老师上的&#xff0c;课没给我留下多深的印象&#xff0c;女老师倒是给我留下了深刻的印象&#xff0c;温柔&#xff0c;漂亮、高挑。上完每节课老师都把ppt和资料发到…

基于Android与多媒体的英文学习APP的设计

毕业设计&#xff08;论文&#xff09;任务书 第1页 毕业设计&#xff08;论文&#xff09;题目&#xff1a;基于Android与多媒体技术的英文学习APP的设计与实现设计&#xff08;论文&#xff09;要求及原始数据&#xff08;资料&#xff09;&#xff1a;1&#xff0e;综述国…

深入理解Java虚拟机:(一)Java代码是如何运行的?

jdk 的子目录下也存在一个 jre。 而我 C盘目录下也有一个 jre。 这两个 jre 有啥联系吗&#xff1f; 答案是&#xff1a;没有联系。甚至准确的来说&#xff0c;它俩是一样的&#xff0c;无论是用哪一个都是可以的。只是很多人习惯将会单独安装另一个 jre&#xff0c;虽然单独…

017 | JavaWeb企业进销存管理系统源码附带毕业设计论文 | 大学生毕业设计 | 极致技术工厂

进销存管理系统是一个基于Internet的应用系统&#xff0c;它是一个面对当前的进销存管理工作基本还处于手工和半信息自动化处理状态而应运而生的一个基于Internet的一个完全信息自动化的系统&#xff0c;整个系统从符合操作简便、界面友好、灵活、实用、安全的要求出发&#xf…

100天精通Python(数据分析篇)——第68天:Pandas数据清洗函数大全

文章目录每篇前言1. duplicated()2. drop_duplicates()3. isnull()4. notnull()5. dropna()6. fillna()7. ffill()8. bfill()9. replace()10. str.replace()11. str.split.str()每篇前言 &#x1f3c6;&#x1f3c6;作者介绍&#xff1a;Python领域优质创作者、华为云享专家、阿…

在PostgreSQL中通过dblink兼容Oracle数据库中的自治事务

1、数据库事务原子性的局限与自治事务 1.1、事务原子性概述 如下所示&#xff0c;如果一个事务中有A和B两个数据的插入操作&#xff0c;当A的SQL语句执行成功后&#xff0c;因为某种原因&#xff08;如服务器断电等&#xff09;&#xff0c;导致B的SQL语句执行失败&#xff0…

微服务框架 SpringCloud微服务架构 微服务保护 32 隔离和降级 32.3 线程隔离【舱壁模式】

微服务框架 【SpringCloudRabbitMQDockerRedis搜索分布式&#xff0c;系统详解springcloud微服务技术栈课程|黑马程序员Java微服务】 微服务保护 文章目录微服务框架微服务保护32 隔离和降级32.3 线程隔离【舱壁模式】32.3.1 线程隔离【舱壁模式】32.3.2 案例32.3.3 总结32 隔…

【BBuf的CUDA笔记】一,解析OneFlow Element-Wise 算子实现

0x0. 前言 由于CUDA水平太菜&#xff0c;所以一直没写过这方面的笔记。现在日常的工作中已经不能离开写CUDA代码&#xff0c;所以准备学习ZZK随缘做一做CUDA的笔记记录一下学习到的知识和技巧。这篇文章记录的是阅读OneFlow的Element-Wise系列CUDA算子实现方案学习到的技巧&am…

MySQL主从复制与读写分离

目录 前言 一、MySQL主从复制的理解 1、MySQL的复制类型 2、MySQL主从复制的工作流程 3、MySQL架构&#xff08;一主多备&#xff09; 3.1 一主多备 3.2 M-S-S 3.3 M-M/双主互备 &#xff08;互为主从&#xff09; 3.4 M-M-M 4、MySQL主从复制延迟原因 5、MySQL主从…

FL Studio2023最新版编曲音乐制作数字音频软件

FL Studio2023即“Fruity Loops Studio”&#xff0c;也就是众所熟知的水果软件&#xff0c; 全能音乐制作环境或数字音频工作站&#xff08;DAW&#xff09;。FL Studio可以编曲、剪辑、录音、混音&#xff0c;让你的计算机成为全功能录音室。 FL Studio2023是一个完整的软件音…

学术分享 | 清华大学 康重庆:电力系统碳计量技术与应用(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️❤️&#x1f4a5;&#x1f4a5;&#x1f4a5;​ &#x1f4cb;&#x1f4cb;&#x1f4cb;本文目录如下&#xff1a;⛳️⛳️⛳️ 目录 ​ 0 写在最前面 1 学术分享 | …

MATLB|改进遗传算法优化微电网调度(考虑环境)

&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️❤️&#x1f4a5;&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑…

Redis 高可用之持久化

Redis 高可用之持久化Redis 高可用什么是高可用Redis的高可用技术Redis持久化持久化的功能Redis提供两种方式进行持久化&#xff1a;RDB持久化触发条件bgsave执行流程启动时加载AOF持久化&#xff08;支持秒级写入&#xff09;开启AOF执行流程启动时加载RDB和AOF的优缺点RDB持久…

CSC7261M

CSC7261M是一款内置高压MOS的高性能、多工作模式的PWM控制芯片&#xff0c;内置多种保护机制。当系统为空载和轻载时&#xff0c;芯片采用Burst和Green控制模式可有效地减少了空载和轻载时的损耗。当系统为中载和重载时&#xff0c;CSC7261M芯片采用CCM模式可有效提升电源系统的…

校招面试中常见的算法题整理【长文】

⭐️我叫恒心&#xff0c;一名喜欢书写博客的研究生在读生。 原创不易~转载麻烦注明出处&#xff0c;并告知作者&#xff0c;谢谢&#xff01;&#xff01;&#xff01; 这是一篇近期会不断更新的博客欧~~~ 有什么问题的小伙伴 欢迎留言提问欧。 文章目录前言一、链表问题1 合并…