信我所行
05
25
网络编程 网络编程
网络编程1.常见的网络架构1.1 客户端/服务器(Client/Server)用户在本地需要下载并且安装客户端程序,在远程有一个服务器端程序。例如:QQ,Stream… 特征: 画面精美,用户体验好 需要开发客户端和
2023-05-25
25
多线程编程 多线程编程
多线程编程1. 线程和进程1.1 线程线程是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。 1.2 进程进程是程序的基本执行实体。 2. 并发和并行2.1 并发在同一时刻,有多个指令在单个CPU上交替执行。
2023-05-25
23
位运算 位运算
位运算(二进制运算)1. 基础知识1.1 原码,反码,补码1.1.1 原码将一个整数转换成二进制形式,就是其原码。例如a = 6; a 的原码就是0000 0000 0000 0110;更改 a 的值a = -18; 此
2023-05-23
23
高精度 高精度
高精度1. 高精度加法 💡 ( A + B )( len(A) , len(B) <= $10^6$) 1.1 算法思想:两个大的数**A + B ( len <= $10^6$)在计算时候,可以使用高精
2023-05-23
16
拓扑排序 拓扑排序
💡 拓扑排序思想:有向无环图(DAG图) 1. 拓扑排序算法思想:拓扑排序是指将一个有向无环图(Directed Acyclic Graph简称DAG)进行排序进而得到一个有序的线性序列。利用拓扑排序可以将事件按照顺序排序后进行处理,
2023-05-16
16
Python基础语法 Python基础语法
Python基础语法1. 标识符,关键字和保留字1.1 标识符在 Python 中,标识符是用来给变量、函数、类等命名的。Python 中的标识符需遵循以下规则: 标识符由字母、数字和下划线组成。 标识符第一个字符必须是字母或下划线。 标
2023-05-16
15
最短路 最短路
最短路(Dijkstra, Bellman-ford, SPFA, Floyd) 1. Dijsttra1.1 素版Dijkstra算法(稠密图——邻接矩阵) 💡时间复杂度:$O(N^2)$ 1.1.1 朴素版Dijkstra算法思想
2023-05-15
15
树和图的遍历 树和图的遍历
树与图的遍历1. 树与图的存储**树与图的存储** 树是一种特殊的图,与图的存储方式相同。 对于无向图中的边ab,存储两条有向边a->b, b->a。 因此我们可以只考虑有向图的存储。 (1) 邻接矩阵:g[a][b] 存储边
2023-05-15
15
BFS BFS
BFS—宽度优先搜索 💡 BFS是一个对连通图进行遍历的算法。它的思想是从一个被选定的点出发;然后从这个点依次向所有方向每散发,每次直走一步。(即其中一个方向走完一步之后换下一个方向继续走);如果得不到目的解,那就返回事先定好的值,如果
2023-05-15
15
DFS DFS
DFS——深度优先搜索 💡 DFS:深度优先搜索算法(Depth-First-Search)是一种用于遍历或搜索树或图的算法.沿着树的深度遍历树的节点,尽可能深的搜索树的分支。当节点v的所在边都己被探寻过,搜索将回溯到发现节点v的那条边
2023-05-15
12
java编码规范 java编码规范
Java编码规范 💡 俗话说: “没有规矩不成方圆”。 编程工作往往都是一个团队协同进行, 因而一致的编码规范非常有必要, 这样写成的代码便于团队中的其他人员阅读, 也便于编写者自己以后阅读。 命名规范 主要的命名方法有一下两种 匈
2023-05-12
12
java基础语法 java基础语法
Java基础语法1. 标识符,关键字和保留字1.1 标识符标识符就是变量、常量、方法、枚举、类、接口等由程序员指定的名字。构成标识符的字母均有一定的规范,Java语言中标识符的命名规则如下: 区分大小写:Myname与myname是两个不
2023-05-12
12
二分 二分
二分查找1.整数二分 💡 时间复杂度:$logN$ (a)快速排序算法实现方式:有单调性一定可以二分,可以二分不一定有单调性 二分查找是通过将一个有序序列划分为两个区间,通过不断的缩小区间的大小在不同的区间寻找答案的一种方式,相比与顺序
2023-05-12
08
排序算法 排序算法
1.快速排序(Quick sort) 💡 时间复杂度:$N*log N$ (a)快速排序算法实现方式: 快速排序的核心思想是分治法,分而治之。它的实现方式是每次从序列中选出一个基准值,其他数依次和基准值做比较,比基准值大的放右边,比基准
2023-05-08