自定义博客皮肤VIP专享

*博客头图:

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

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

博客底图:

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

栏目图:

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

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

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

原创 树和二叉树

树和二叉树树结构是一类重要的非线性数据结构。直观来看,树是以分支关系定义的层次结构。树结构在客观世界中广泛存在,如人类社会的族谱和各种社会组织机构都可用树来形象表示。树在计算机领域中也得到广泛应用,尤以二叉树最为常用。如在操作系统中,用树来表示文件目录的组织结构,在编译系统中,用树来表示源程序的语法结构,在数据库系统中,树结构也是信息的重要组织形式之一。树和二叉树的定义树的定义树(Tree)是n(n≥0)个结点的有限集,它或为空树(n=0);或为非空树,对于非空树T:有且仅有一个称之为根的结点;

2022-01-04 10:34:09 324

原创 Linux之fork()函数进程笔记

Linux 线程学习笔记一、什么是进程一个可执行的完整的程序,包含有自己的代码正文区、数据存储区、进程执行过程中的上下文(程序计数器的值与寄存器内容)信息,总结来说就是由程序段、数据段、进程控制块三部分组成;进程是系统进行资源分配和调度的基本单位,因此可以认为进程是活动的,它表示每一次调度执行后当前程序的一个活动,这个活动里包含了当前程序下一条要执行的指令、以及需要操作的数据;二、进程怎么执行进程是CPU调度的基本单元,所以CPU中是存在多个进程的,而某个进程在执行过程中并不会一直占据CPU资源,

2021-05-11 09:22:36 381 4

原创 c/c++实现二叉树的创建以及前中后序遍历

二叉树(Binary tree)是树形结构的一个重要类型。许多实际问题抽象出来的数据结构往往是二叉树形式,即使是一般的树也能简单地转换为二叉树,而且二叉树的存储结构及其算法都较为简单,因此二叉树显得特别重要。二叉树特点是每个结点最多只能有两棵子树,且有左右之分。遍历方式前序遍历:root -> left -> right中序遍历:left -> root -> right后续遍历:left ->right -> root思路:利用结构体替代二叉树,并利用递归的

2021-04-01 00:20:17 1033

原创 创建LVM类型的Storage Pool

1. 环境准备添加一块磁盘 /dev/sdb先给虚拟机添加一块硬盘之后下一步即可2. 创建并使用LVM逻辑卷和PV物理卷即VG卷组(1)检查可用的磁盘分区:(2)创建PV=pvcreate 设备名称 ……没有pvcreate 以及 vgcreate的使用 sudo apt-get install lvm2下载一下注意:这里最好进入一下root用户。不然以后会一直报权限问题查看(3)创建VG=vgcreate 卷组名称 设备成员 …...

2021-03-26 00:24:05 1795

原创 创建你的第一个KVM虚拟机

1.在VmWare中安装Ubuntu下载Ubuntu的镜像,14.04、16.04、18.04以供来学习。下载各个版本的iso镜像,然后再虚拟机中一路next推荐即可,注意的是,再选择共享文件夹时要选择单个文件。安装Ubuntu系统,其他的博客有很多,可自行去搜索,这里主要说一下安装中可能会存在的一些问题。(此处以Ubuntu18.04举例)1.安装完成后再VMWare WorkStation中会只有中间一小块屏幕的问题存在问题解决问题问题说明:因为没有安装VMware Tools

2021-03-06 11:03:34 3523 9

原创 多线程详解(1)

1.线程简介什么是线程?

2021-03-04 00:00:59 147 1

转载 面向对象编程

1. 什么是面向对象面向过程思想步骤清晰简单,第一步做什么,第二步做什么…面对过程适合处理一些较为简单的问题面向对象思想物以类聚,分类的思维模式,思考问题会解决问题需要哪些分类,然后对这些分类进行单独思考。最后,才对某个分类下的细节进行面向过程的思索。面向对象适合处理复杂的问题,适合处理需要多人协作的问题!对于描述复杂的事物,为了从宏观上把握,从整体上合理分析,我们需要使用面向对象的思路来分析整个系统。但是,具体到微观操作,仍然需要面向过程的思路去处理。面向对象编程(Obj

2021-02-25 19:10:21 113

原创 JAVA方法详解

1. 何为方法?System.out.println(),那么它是什么呢?JAVA方法是语句的集合,它们在一起执行一个功能。方法是解决一类问题的步骤的有序组合方法包含于类或对象中方法在程序中被创建,在其他地方被引用设计方法的原则:方法的本意是功能块,就是实现某个功能的语句块的集合。我们设计方法的时候,最好保持方法的原子性,就是一个方法只完成一个功能,这样利于我们后期的扩展。2. 方法的定义和调用JAVA的方法类似于其他语言的函数,是一段用来完成特定功能的代码片段,一般情况下,定义一个

2021-02-25 14:06:32 98

原创 JAVA流程控制

1. 用户交互Scanner之前我们学习的基础语法中并没有实现程序和人的交互,但是Java给我们提供了一个这样的工具类,我们可以获取用户的输入。java.util.Scanner是Java 5的新特性,我们可以通过Scanner来获取用户的输入。基本的语法Scanner s = new Scanner(System.in);通过Scanner类的next()与nextLine()方法获取输入的字符串,在读取前我们一般需要使用hasNext() 与 hasNextLine()判断是否还有输入的数

2021-02-25 10:01:49 116 2

原创 JAVA基础语法(2)

6. 基本运算符java语言支持以下运算符算数运算符:+,-,*,/,%,++,–赋值运算符:=关系运算符:>,<,>=,<=,==,!=,instanceof逻辑运算符:&&,||,!条件运算符: ?:扩展赋值运算符:+=,-=,/=,*= long a = 1153132165465155L; int b = 1234; short c = 10; byte d = 1; //相

2021-02-24 16:43:47 82

原创 JAVA基础语法(1)

1、注释//单行注释/* 多行注释 *//*** @Description 文档注释* @author 某某 */2、标识符和关键字标识符定义1、 包名、类名、方法名、参数名、变量名等,这些符号被称为标识符。2、 标识符可以由字母、数字、下划线(_)和美元符号($)组成3、 标识符不能以数字开头,不能是java中的关键字。例如:正确的标识符Username、username123、user_name、_userName、$username不正确的标识符:123us

2021-02-24 15:06:35 146

转载 JAVA入门简介

JAVA的发展历史1. C语言帝国的统治现在是公元1995年, C语言帝国已经统治了20多年, 实在是太久了。1972年, 随着C语言的诞生和Unix的问世, 帝国迅速建立统治, 从北美到欧洲, 从欧洲到亚洲, 无数程序员臣服在他的脚下。帝国给我们提供了极好的福利:贴近硬件, 运行极快, 效率极高。使用这些福利, 程序员们用C 开发了很多系统级软件,操作系统, 编译器, 数据库,网络系统……但是帝国也给程序员们安上了两个沉重的枷锁: 指针和内存管理虽然指针无比强大, 能直接操作内存, 但是帝国

2021-02-24 09:09:32 101

原创 栈--简单计算器(后缀表达式)

JAVA实现后缀表达式–>简单计算器(栈)预备知识:前缀表达式中缀表达式后缀表达式比如 5 * 2 + 3前缀表达式 : + * 5 2 3中缀表达式:5 * 2 + 3后缀表达式:5 2 * 3 +计算机中,使用后缀表达式更容易进行计算:思想:遇到数字就入栈,遇到运算符就pop出两个数进行运算然后将结果入栈。最后留下一个栈顶元素即为结果。可见,实现后缀表达式计算出并不困难。这里的难点是怎么把我们常用的中缀表达式转换成后缀表达式:这里先说中缀表达式的思想:初始化两

2020-11-30 00:27:10 428 1

原创 JAVA栈实现简单的计算器

本次使用栈来模拟计算器的实现例如 15 + 2 × 3 - 3我们需要两个栈来辅助实现符号栈(用来存储符号)数字栈(用来存储运算的数字和结果)实现思路:5+2*3-31.通过一个index值(索引),来遍历我们的表达式2.如果我们发现是一个数字。就直接入数栈3.如果发现扫描到的是一个符号,就分如下情况3.1 如果发现当前的符号栈为空,就直接入符号栈。3.2 如果符号栈有操作符,就进行比较。1)如果当前的操作符的优先级小于或者等于栈中的操作符,这时就需要从数栈中pop出两个数

2020-11-29 23:35:15 817 1

原创 java实现栈-数据结构

栈(stack)1)栈是一个先入后出(FILO-First In Last Out)的有序列表2)栈(stack)是限制线性表中元素的插入和删除只能在线性表的同一端进行的一种特殊线性表。允许插入和删除的一端,为变化的一段,成为栈顶(Top),另一端为固定的一端,称为栈底(Bottom)。3)根据栈的定义可知,最先放入栈中的元素在栈底,最后放入的元素在栈顶,而删除元素刚好相反,最后放入的元素最先删除,最先放入的元素最后删除。入栈(push)的图解:出栈(pop)栈的应用场景1)子程序的调用:

2020-11-24 08:31:19 281 2

原创 数据结构——单链表(JAVA)

数据结构——单链表单链表是一种链式存取的数据结构,用一组地址任意的存储单元存放线性表中的数据元素。链表中的数据是以结点来表示的,每个结点的构成:元素(数据元素的映象) + 指针(指示后继元素存储位置),元素就是存储数据的存储单元,指针就是连接每个结点的地址数据。起初我们创建一个节点类//英雄节点class HeroNode { public int no; //英雄编号 public String name; //名称 public String nickname; //绰号

2020-11-14 08:07:51 180

原创 JAVA代码实现环形队列

环形队列在上一篇中提到了顺序队列的实现,顺序队列存在的最大的问题就是假上溢现象。"假上溢"现象:由于入队和出队操作中,头尾指针只增加不减小,致使被删元素的空间永远无法重新利用。当队列中实际的元素个数远远小于向量空间的规模时,也可能由于尾指针已超越向量空间的上界而不能做入队操作。该现象称为"假上溢"现象。环形队列解决了这一缺陷,将队列空间充分重复利用。以下是思路图:这里的思想稍微有一点点变化:起初 front = rear = 0 ,每当添加元素时,将rear++ ,这里判断队满的条件是 (rea

2020-11-09 22:33:47 353

原创 JAVA实现简单的顺序队列

JAVA实现队列队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。队列中没有元素时,称为空队列。队列的数据元素又称为队列元素。在队列中插入一个队列元素称为入队,从队列中删除一个队列元素称为出队。因为队列只允许在一端插入,在另一端删除,所以只有最早进入队列的元素才能最先从队列中删除,故队列又称为先进先出(FIFO—first in first o

2020-11-09 16:13:01 431

原创 算法设计--JAVA实现稀疏矩阵

稀疏矩阵在矩阵中,若数值为0的元素数目远远多于非0元素的数目,并且非0元素分布没有规律时,则称该矩阵为稀疏矩阵;与之相反,若非0元素数目占大多数时,则称该矩阵为稠密矩阵。定义非零元素的总数比上矩阵所有元素的总数为矩阵的稠密度。此处使用JAVA代码实现对矩阵的压缩与扩展可以想象,当我们玩五子棋或其他棋类游戏时,当我们需要对游戏来进行存档。那么可以把棋盘来当作一个矩阵,有棋子的地方用相应的数字来进行表示。没有棋子的地方用0来表示。这里假设棋盘为11*11的一个矩阵。倘若棋盘中1为黑子,2为白子。原始

2020-11-09 12:29:12 509

原创 C++实现快速排序

C++快速排序这里对数组{2,4,6,8,10,1,7,44,5,9,3,0};进行排序。先利用fous来存数组第一个元素或者最后一个元素当做即将成为的"中间"元素。利用i来找从左边到右边一个比fous大的元素。利用j来找从右边到左边一个比fous小的元素。比如第一趟:fous=2,此时先找j的元素,j一开始记录数组最后一个元素也就是0。0小于2,所以a[11]的值赋予a[0]。(此...

2020-05-03 00:00:37 177

原创 C++实现插入排序全过程

C++实现插入排序大家好,第一次发表自己的文章。初心是想为学习算法的朋友提供力所能及的帮助。本次带来的是插入排序。插入排序的思想很简单,将一组数据分成两组,我分别将其称为有序组与待插入组。每次从待插入组中取出一个元素,与有序组的元素进行比较,并找到合适的位置,将该元素插到有序组当中。过程分析比如我们要实现顺序的数组是a[]={9,3,4,2,6,7,5,1};那么我们可以把他们每一趟的顺...

2020-05-02 09:24:38 1972

空空如也

空空如也

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

TA关注的人

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