自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(27)
  • 收藏
  • 关注

原创 堆排序总结

1.算法原理算法基于顺序存储的“完全二叉树”:结点i的左孩子是2i;右孩子是2i+1;父节点是i/2;编号小于n/2的结点都是分支结点。大根堆(根>=左、右),小根堆(根<=左、右)建堆:编号<=n/2的所有结点依次”下坠“调整(自底向上处理分支结点),调整规则:小元素逐层”下坠“(与关键字更大的孩子交换)。排序:将栈顶元素加入有序子序列(栈顶元素与栈底元素交换),栈底元素换到栈顶后,需要进行”下坠“调整,恢复”大根堆“的特性;重复上述重复n-1趟。2.具体代码//第一部分

2020-09-27 19:45:28 400

原创 归并算法总结

1.算法原理把两个或多个有序的子序列合并为一个2.归并排序算法步骤若low<high,则将序列从中间mid=(low+high)/2分开对左半部分[low,mid]递归地进行归并排序对右半部分[mid+1,high]递归地进行归并排序将左右两个有序的子序列Merge为一个3.具体算法#include<stdio.h> #include<stdlib.h>#include<string.h>void Merge(int A[],int B[]

2020-09-25 17:51:03 481

原创 简单选择排序总结

1.算法原理每一趟在待排序元素中选取关键字最小的元素加入有序子序列,必须进行总共n-1趟处理。2.具体算法//第一部分:排序算法//9-5 简单选择排序//2020.09.24 void swap(int *x,int *y){ int temp; temp=*x; *x=*y; *y=temp;}void SelectSort(int A[],int n){ int i,j,min; for(i=0;i<n-1;i++) { min=i;//每轮选择前都将i定位

2020-09-24 16:16:10 188

原创 直接插入排序算法总结

1.直接插入排序算法原理算法思想:每次将一个待排序的记录按其关键字大小插入到前面已排好的子序列中,知道全部记录插入完成。2.具体算法//第一部分:排序算法//9-3 直接插入排序//2020.09.22 //直接插入排序void InsertSort(int A[],int n){ int i,j; int temp; for(i=1;i<n;i++)//将各元素插入已排好的序列中 { if(A[i]<A[i-1])//若A[i]的关键字小于前驱 { t

2020-09-24 15:42:05 389

原创 希尔排序算法总结

1.算法原理希尔排序:先将待排序表分割成若干形如L[i,i+d,i+2d,…,i+kd]的“特殊”子表,对各子表分别进行直接插入排序。缩小增量d,重复上述过程,直到d=1为止。2.具体算法//第一部分:排序算法//9-4 希尔排序//2020.09.23 //先追求表中元素部分有序,再逐渐逼近全局有序 void ShallSort(int A[],int n){ int d,i,j; for(d=n/2;d>=1;d/=2)//步长变化 for(i=d+1;i<n;i++

2020-09-24 15:24:57 193

原创 冒泡排序总结

1.冒泡排序算法的基本原理从后往前(或从前往后)两两比较相邻元素的值,若为逆序,则交换它们,直到序列比较完。称这样过程为一趟冒泡排序,最多只需n-1趟排序。每一趟排序都可以使一个元素移动到最终位置,已经确定最终位置的元素在之后的处理中无需再对比。如果某一趟排序过程中未发生“交换”,则算法可提前结束。2.具体算法//第一部分:排序算法//9-1 冒泡排序//2020.09.20 void swap(int *x,int *y)//交换函数{ int temp; temp = *x; *

2020-09-22 13:27:01 828

原创 快速排序总结

1.快速排序算法思想快速排序的思想是在数组[p,r]中选择一个分区点q,将数组一分为2,同时将小于分区点的数值的放到分区点左侧[p,q-1],大于分区点的数值的放到分区点右侧[q+1,r],重复这个过程。2.具体算法代码//第一部分:查找算法//9-1 快速排序//2020.09.20 void QuickSort(int arr[],int low,int high){ int temp; int i=low,j=high; if(low<high) { temp=arr[

2020-09-20 11:47:08 85

原创 左旋转字符串(C++)

1.题目描述汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它!2.具体算法遍历字符串数组法class Solution {public: string LeftRotateString(string str, int n) { if(

2020-08-02 00:48:01 232

原创 数值的整数次方(快速幂的两种方法)

1.题目描述给定一个double类型的浮点数base和int类型的整数exponent。求base的exponent次方。保证base和exponent不同时为02.具体算法- 递归快速幂算法class Solution {public: double Power(double base, int exponent) { if(exponent<0) { base = 1/base; exponent

2020-07-30 01:34:29 341

原创 旋转数组的最小数字

1.题目描述把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。2.具体算法class Solution {public: int minNumberInRotateArray(vector<int> rotateArray) { if(rot

2020-07-25 01:29:21 69

原创 两个链表的第一个公共结点(C++)

1.题目描述输入两个链表,找出它们的第一个公共结点。2.具体算法/*struct ListNode { int val; struct ListNode *next; ListNode(int x) : val(x), next(NULL) { }};*/class Solution {public: ListNode* FindFirstCommonNode( ListNode* pHead1, ListNode* pHead2) { ListNode*

2020-07-22 01:35:34 456

原创 整数中1出现的次数(从1到n中1出现的次数)

1.题目描述求出1-13的整数中1出现的次数,并算出100~1300的整数中1出现的次数?为此他特别数了一下1-13中包含1的数字有1、10、11、12、13因此共出现6次,但是对于后面问题他就没辙了。ACMer希望你们帮帮他,并把问题更加普遍化,可以很快的求出任意非负整数区间中1出现的次数(从1 到 n 中1出现的次数)。2.具体算法class Solution {public: int NumberOf1Between1AndN_Solution(int n) {

2020-07-20 01:12:55 445

原创 二进制中1 的个数(C++)

1.题目描述输入一个整数,输出该数32位二进制表示中1的个数。其中负数用补码表示。2.具体算法正确算法class Solution {public: int NumberOf1(int n) { int i = 0; int flag = 1;//定义一个值为1的flag变量 while(flag!=0)//当flag为0时,flag溢出,循环结束 { if((flag&n)!

2020-07-19 01:50:13 838

原创 矩形覆盖(C++)

1.题目描述我们可以用21的小矩形横着或者竖着去覆盖更大的矩形。请问用n个21的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法?比如n=3时,2*3的矩形块有3种覆盖方法:2.具体算法class Solution {public: int rectCover(int number) { if(number<1)// return 0; else if(number==1||number==2)

2020-07-17 00:46:20 604

原创 判断平衡二叉树

1.题目描述输入一棵二叉树,判断该二叉树是否是平衡二叉树。 在这里,我们只需要考虑其平衡性,不需要考虑其是不是排序二叉树2.具体算法class Solution {public: bool IsBalanced_Solution(TreeNode* pRoot) { if(pRoot==NULL) return true;//当根节点为空是,返回true int LeftDepth = Get_Depth(pRoot->left)

2020-07-16 12:59:27 2906

原创 用两个栈实现队列

1.题目描述用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。2.具体算法class Solution{public: void push(int node) { stack1.push(node);//将node压入stack1中 } int pop() { int ref;//定义ref为记录出栈的元素 if(!stack2.empty())//记录stack2不为空时的情况

2020-07-15 10:56:32 76

原创 线性表的定义和基本操作

1.线性表的定义线性表是具有相同数据类型的n(n≥0)个数据元素的有限序列,其中n为表长,当n = 0时线性表是一个空表。若用L命名线性表,则其一般表示为 L= (a1, a2, …, ai, ai+1,… , an)。几个概念:ai是线性表中的“第i个”元素线性表中的位序 ,a1是表头元素;an是表尾元素。除第一个元素外,每个元素有且仅有一个直接前驱;除最后一个元素外,每个元素有且仅有一个直接后继。2.线性表的基本操作1. 为什么要实现对数据结构的基本操作?团队合作编程,你定义的数据结构要

2020-07-14 11:29:44 1198

原创 数据结构基本概念

1.数据结构在学什么?如何用程序代码把现实世界的问题信息化 ;如何用计算机高效地处理这些信息从而创造价值。2.数据结构有关的基本概念数据:数据是信息的载体,是描述客观事物属性的数、字符及所有能输入到计算机中并被计算机程序识别 和处理的符号的集合。数据是计算机程序加工的原料。数据元素、数据项: 数据元素是数据的基本单位,通常作为一个整体进行考虑和处理。一个数据元素可由若干数据项组成,数据项是构成数据元素的不可分割的最小单位。数据结构:数据结构是相互之间存在一种或多种特定关系的数据元素的集合

2020-07-13 12:24:31 156

原创 算法效率的度量

1.时间复杂度1. 如何计算?找到一个基本操作(最深层循环);分析该基本操作的执行次数x与问题规模n的关系x=f(n);x的数量级O(x)就是算法时间复杂度T(n);2.常用技巧加法规则:O(f(n))+O(g(n)) = O(max(f(n),g(n)))乘法规则:O(f(n))*O(g(n)) = O(f(n)*g(n))O(1)<O(log2n)<O(n)<O(nlog2n)<O(n2) <O(n3)<O(2n)<O(n!)<O(n

2020-07-13 12:00:13 450

原创 算法基本概念

1.什么是算法?程序=数据结构+算法数据结构:数据结构是要处理的信息;算法:算法是处理信息的步骤;程序设计::设计一个好的数据结构;设计一个好的算法;2.算法的五个特性(算法必须具备的特性)有穷性:有穷时间内能执行完;算法时有穷的;程序可以是无穷的。确定性:相同输入只会产生相同输出;可行性:可以用已有的基本操作实现算法;输入:丢给算法处理的数据;输出:算法处理的结果;3.“好”算法的特质(设计算法时要尽量追求的目标)正确性:能正确解决问题可读性:对算法的描述要让其他人也

2020-07-13 11:47:36 90

原创 连续子序列的最大和

1.题目描述HR偶尔会拿些专业问题来忽悠那些非计算机专业的同学。今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决。但是,如果向量中包含负数,是否应该包含某个负数,并期望旁边的正数会弥补它呢?例如:{6,-3,-2,7,-15,1,2,2},连续子向量的最大和为8(从第0个开始,到第3个为止)。给一个数组,返回它的最大连续子序列的和,你会不会被他忽悠住?(子向量的长度至少是1)2.具体算法class Solution {publ

2020-07-13 11:15:21 216

原创 构建乘积数组

1.题目描述给定一个数组A[0,1,…,n-1],请构建一个数组B[0,1,…,n-1],其中B中的元素B[i]=A[0]A[1]…*A[i-1]A[i+1]…*A[n-1]。不能使用除法。(注意:规定B[0] = A[1] * A[2] * … * A[n-1],B[n-1] = A[0] * A[1] * … * A[n-2];)2.具体算法class Solution {public: vector<int> multiply(const vector<int>

2020-07-10 15:31:17 108

原创 求1+2+3+...+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。(C++)

1.具体算法class Solution {public: int Sum_Solution(int n) { int term = n; (term-1)&&(term+=Sum_Solution(term-1)); return term; }};2.算法的总结这个算法的难点是在计算时不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C),所以只能用‘&a

2020-07-09 16:57:29 271

原创 一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。(C++)

1.具体算法class Solution {public: int jumpFloorII(int number) { if(number==1) { return 1; } else{ return 2*jumpFloorII(number-1); } }};2.算法推导与总结这个算法的难度在于数学的推导过程,一旦把握了算法的核心数学表达式,所有的

2020-07-09 12:05:03 1048

原创 操作给定的二叉树,将其变换为源二叉树的镜像。(C++)

1.具体算法/*struct TreeNode { int val; struct TreeNode *left; struct TreeNode *right; TreeNode(int x) : val(x), left(NULL), right(NULL) { }};*/class Solution {public: void Mirror(TreeNode *pRoot) { if(!pRoot)//首先判断pRoot节点是否为空,如果为空则算法结束

2020-07-09 01:54:32 354

原创 输入一棵二叉树,求该树的深度。从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度。(C++)

输入一棵二叉树,求该树的深度。从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度。(C++)1.具体的算法/*struct TreeNode { int val; struct TreeNode *left; struct TreeNode *right; TreeNode(int x) : val(x), left(NULL), right(NULL) { }};*/class Solution {public: int TreeD

2020-07-08 17:36:02 1094

原创 写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。

写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。(C++)1.首先给出代码展示:class Solution {public:    int Add(int num1, int num2)    {        while(num2!=0)        {&nb

2020-07-06 18:22:44 1057

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除