计算机网络第四章

news2024/12/28 19:49:32

1.网络层

主要任务是把分组从源端传到目的端,为分组交换网上的不同主机提供通信服务,网络层传输单位是数据报

三个功能:

  1. 路由选择与分组转发(最佳路径

  1. 异构网络互联

  1. 拥塞控制

    • 数据交换方式

三种交换方式:电路交换、报文交换、分组交换

    • 电路交换

特点:独占资源

优点

缺点

通信时延小

建立连接时间长

有序传输

线路独占,使用效率低

没有冲突

灵活性差

实时性强

无差错控制能力

2.报文交换

报文:原应用发送的整体

特点:中间使用交换机进行存储转发

优点

缺点

无需建立连接

有存储转发时延

存储转发,动态分配线路

报文大小不定,需要网络节点有较大缓存空间

线路可靠性较高

线路利用率较高

多目标服务

3.分组交换

分组:把大的数据块分割成小的数据块。

优点

缺点

无需建立连接

有存储转发时延

存储转发,动态分配线路

需要传输额外的信息量

线路可靠性较高

乱序到目的主机时,要对分组排序重组

线路利用率较高

相对于报文交换,存储管理更容易

三种数据交换的总结:

👉报文交换分组交换都采用存储转发

👉传送数据量大,且传送时间远大于呼叫时,选择电路交换。电路交换传输时延最小

👉从信道利用率看,报文交换分组交换优于电路交换,其中分组交换时延更小

4.数据报方式和虚电路方式

数据报方式为网络层提供无连接服务,路由器根据分组的目的地址转发分组: 基于路由协议/算法构建转发表,检索转发表:每个分组独立选路

无连接服务:不事先为分组的传输确定传输路径,每个分组独立确定传输路径,不同分组传输路径可能不同

虚电路方式为网络层提供连接服务,虚电路:一条源主机到目的主机类似于电路的路径(逻辑连接),路径上所有结点都要维持这条虚电路的建立都维持一张虚电路表,每一项记录了一个打开的虚电路的信息

连接服务:首先为分组的传输确定传输路径(建立连接),然后沿该路径(连接)传输系列分组,系列分组传输路径相同,传输结束后拆除连接

数据报和虚电路对比:

数据报服务

虚电路服务

连接的建立

不要

必须有

目的地址

每个分组都有完整的目的地址

仅在建立连接阶段使用,之后每个分组使用长度较短的虚电路号

路由选择

每个分组独立地进行

路由选择和转发

属于同一条虚电路的分组按照同一路由转发

分组顺序

不保证分组的有序到达

保证分组的有序到达

可靠性

不保证可靠通信,可靠性由用户主机来保证

可靠性由网络保证

对网络故障的适应性

出故障的结点丢失分组,其他分组路径选择发生变化,可正常传输

所有经过故障结点的虚电路均不能正常工作

差错处理和流量控制

由用户主机进行流量控制,不保证数据报的可靠性

可由分组交换网负责,也可由用户主机负责

2.路由算法

分为静态路由算法和非静态路由算法

静态路由算法(非自适应路由算法)

管理员手工配置路由信息。

简便、可靠,在负荷稳定、拓扑变化不大的网络中运行效果很好,广泛用于高度安全性的军事网络和较小的商业网络。

缺点:路由更新慢,不适用大型网络

动态路由算法(自适应路由算法)

路由器间彼此交换信息,按照路由算法优化出路由表项

路由更新快,适用大型网络,及时响应链路费用或网络拓扑变化

缺点:算法复杂,增加网络负担

动态路由算法又分两种:全局性和分散性

全局性:链路状态路由算法 OSPF,所有路由器掌握完整的网络拓扑和链路费用信息

分散性:距离向量路由算法 RIP,路由器只掌握物理相连的邻居及链路费用

自治系统AS:在单一的技术管理下的一组路由器,而这些路由器使用一种AS内部的路由选择协议和共同的度量以确定分组在该AS内的路由,同时还使用一种AS之间的路由协议以确定在AS之间的路由

一个AS内的所有网络都属于一个行政单位来管辖,一个自治系统的所有路由器在本自治系统内都必须连通

3.IP地址

IPV4数据报格式和IPV4数据报分片

IP地址:全世界唯一的32位/4字节标识符,标识路由器主机的接口

IP地址的分类及数量⬇

网络类别

最大可用网络数

第一个可用的网络号

最后一个可用的网络号

每个网络中的最大主机数

A

2^7-2

1

126

2^24-2

B

2^14-1

128.1

191.255

2^16-2

C

2^21-1

192.0.1

223.255.255

2^8-2

网络地址转换NAT技术:在专用网连接到因特网的路由器上安装NAT软件,安装了NAT软件的路由器叫NAT路由器,它至少有一个有效的外部全球IP地址,也就是可以使内网访问到外网

1.子网划分

145.13.3.10

两级IP地址

145        13

3       10

名称

网络号

主机号

两级IP地址的子网掩码

11111111   11111111

00000000     00000000

名称

网络号

子网号

主机号

三级IP地址

145   13

3

10

三级IP地址的子网掩码

11111111    11111111

11111111

00000000

子网掩码与IP地址逐位相写,就得到子网网络地址

子网的网络地址

145   13    3    0

子网掩码:如果是两级IP地址对应的网络号写全1,对应的主机号写全0,如果是三级IP地址对应的网络号写全1,对应的子网号写全1,对应的主机号写全0

在广播分组中主机号要写全1

一些需要记住的二进制转十进制:

二进制

十进制

10000000

128

11000000

192

11100000

224

11110000

240

11111000

248

11111100

252

11111110

254

11111111

255

2.无分类编址CIDR

概念:

1.消除了传统的A类,B类和c类地址以及划分子网的概念

2.融合子网地址与子网掩码,方便子网划分

CIDR记法:IP地址后加上“/”,然后写上网络前缀 (可以任意长度)的位数

128.14.32.0/20

前20位

后面的位

名称

网络前缀

主机号

地址掩码

网络前缀全为1

11111111 11111111 1111

主机号全为0

0000 00000000

3.构成超网

概念:将多个子网聚合成一个较大的子网,叫做构成超网,或路由聚合

方法:将网络前缀缩短

使用CIDR时,查找路由表可能得到几个匹配结果,应选择具有最长网络前缀的路由。前缀越长,地址块越小,路由越具体

IP地址的例子:

答案:B

题目中说采用 定长子网划分 ,也就是在无分类编址CIDR的基础上进行子网划分,题目中前24位比特位都是网络前缀,在后面的八位比特位中进行子网划分

从子网掩码 255.255.255.248 可以得出最后的八位比特为 11111000 ,因此前五位比特位都是子网网掩码,所以最大的子网个数 2^5=32,在这里是不需要减2,这里使用了无分类编址CIDR是子网掩码是可以全0和全1的,最大可分配地址个数2^3-2=6,这里减2,是减去了主机号全为0和全为1的情况

4.ARP协议

定义:完成主机或路由器IP地址到MAC地址的映射🔜解决下一跳走哪的问题

ARP协议使用过程:

检查ARP高速缓存,有对应表项则写入MAC帧,没有则用目的MAC地址为FF-FF-FF-FF-FF-FF帧的封装并广播ARP请求分组同一局域网中所有主机都能收到该请求。目的主机收到请求后就会向源主机单播一个ARP响应分组,源主机收到后将此映射写入ARP缓存 (10-20min更新一次)

ARP协议4种典型情况:

  1. 主机A发给本网络上的主机B: 用ARP找到主机B的硬件地址:

  1. 主机A发给另一网络上的机B: 用ARP找到本网络上一个路中器 (网关)的硬件地址

  1. 路由器发给本网络的主机A: 用ARP找到主机A的硬件地址

  1. .路由器发给另一网络的主机B:用ARP找到本网络上的一个路由器的硬件地址

5.DHCP协议

概念:动态主机配置协议DHCP是应用层协议,使用客户/服务器方式,客户端和服务端通过广播方式进行交互,基于UDP

DHCP提供即插即用联网的机制,主机可以从服务器动态获取IP地址、子网掩码、默认网关、DNS服务器名称与IP地址,允许地址重用,支持移动用户加入网络,支持在用地址续租

过程:

  1. 主机广播DHCP发现报文

  1. DHCP服务器广播DHCP提供报文

  1. 主机广播DHCP请求报文

  1. DHCP服务器广播DHCP确认报文

6.ICMP协议

ICMP协议支持主机或路由器:差错(或异常) 报告网络探询

ICMP差错报告报文:

  1. 终点不可达:当路由器或主机不能交付数据报时就向源点发送终点不可达报文。

  1. 时间超过:当路由器收到生存时间TTL=O的数据报时,除丢弃该数据报外,还要向源点发送时间超过报文。当终点在预先规定的时间内不能收到一个数据报的全部数据报片时,就把已收到的数据报片都丢弃,并向源点发送时间超过报文。

  1. 参数问题:当路由器或目的主机收到的数据报的首部中有的字段的值不正确时,就丢弃该数据报,并向源点发送参数问题报文。首部字段有问题

  1. 改变路由(重定向):路由器把改变路由报文发送给主机,让主机知道下次应将数据报发送给另外的路由器(可通过更好的路由)。

7.IPV6地址

❓IPV6数据报格式

IPV6和IPV4对比:

  1. IPv6将地址从32位 (4B) 扩大到128位 (16B),更大的地址空间

  1. IPv6将IPv4的校验和字段底移除,以减少每跳的处理时间

  1. Pv6将IPV4的可选字段移出首部,变成了扩展首部,成为灵活的首部格式,路由器通常不对扩展首部进行检查大大提高了路由器的处理效率

  1. IPv6支持即插即用(即自动配置),不需要DHCP协议

  1. IPv6首部长度必须是8B的整数倍,IPv4首部是4B的整数倍

  1. IPv6只能在主机处分片,IPv4可以在路由器和主机处分片

IPV6地址的表示形式:

一般形式:4BF5:AA12:0216:FEBC:BA5F:039ABE9A:2170

压缩形式:4BF5:0000:0000:0000:BA 5F:039A:000A:2176🔜4BF5:0:0:0:BA5F:39A:A:2176

零压缩:一连串连续的0可以被一对冒号取代

双冒号表示法在一个地址中仅可出现一次

IPV6的基本地址类型:

  • 单播:一对一通信可做源地址+目的地址

  • 多播:一对多通信可,做目的地址

  • 任播:一对多中的一个通信,可做目的地址

IPV6向IPV4过度的策略:

双栈协议:双协议栈技术就是指在一台设备上同时启用IPv4协议栈和IPv6协议栈

隧道技术:通过使用互联网络的基础设施在网络之间传递数据的方式。使用隧道传递的数据(或负载)可以是不同协议的数据帧或包。隧道协议将其它协议的数据帧或包重新封装然后通过隧道发送。

4.路由协议

1.RIP协议

定义:RIP是一种分布式的基于距离向量的路由选择协议,是因特网的协议标准,最大优点是简单

从源端口到目的端口所经过的路由器个数,经过一个路由器跳数+1。特别的,从一路由器到直接连接的网络距离为1。RIP允许一条路由最多只能包含15个路由器,因此距离为16表示网络不可达

收敛:经过若干次更新后,所有路由器最终都会知道到达本自治系统任何一个网络的最短距离和下一跳路由器的地址

距离向量算法步骤:

  1. 对地址为X的相邻路由器发来的RIP报文,修改此报文中的所有项目:把“下一跳”字段中的地址改为X,并把所有的“距离”字段+1

2.对修改后的RIP报文中的每一个项目,进行以下步骤:

(1)R1路由表中若没有Net3,则把该项目填入R1路由表

(2) R1路由表中若有Net3,则查看下一跳路由器地址:

若下一跳是X,则用收到的项目替换源路由表中的项目:

若下一跳不是X,原来距离比从X走的距离远则更新,否则不作处理

3.若180s还没收到相邻路由器X的更新路由表,则把X记为不可达的路由器,即把距离设置为16

4.返回

RIP的特点: 当网络出现故障时,要经过比较长的时间(例如数分钟)才能将此信息传送到所有的路由器,“慢收”

RIP例子

答案:B

题目中说 C到B、D和E延迟分别为6、3和5 所以每一向量都加上对应的延迟得到新向量

C到B:11  6  14  18  12  8

C到D:19  15  9  3  12  13

C到E:12  11  8  14  5  9

从上面上个向量中选择到达每一个点得最短路径,自己到达自己为0,所以最终向量:11  6  0  3  5  8

2.OSPF协议

开放最短路径优先OSPF协议:“开放”标明OSPF协议不是受某一家厂商控制,而是公开发表的:“最短路径优先'是因为使用了Dijkstra提出的最短路径算法SPF

OSPF最主要的特征就是使用分布式的链路状态协议

OSPF得的区域:为了使 OSPF 能够用于规模很大的网络,OSPF 将一个自治系统再划分为若千个更小的范围,叫做区域每一个区域都有一个32 位的区域标识符(用点分十进制表示)

OSPF协议的特点:

  1. 使用洪泛法向自治系统内所有路由器发送信息,即路由器通过输出端口向所有相邻的路由器发送信息,而每一个相邻路由器又再次将此信息发往其所有的相邻路由器

  1. 发送的信息就是与本路由器相邻的所有路由器的链路状态

  1. 只有当链路状态发生变化时,路由器才向所有路由器洪泛发送此信息

3.BGP协议

BGP协议交换信息的过程:BGP 所交换的网络可达性的信息就是要到达某个网络所要经过的一系列 AS。当BGP 发言人互相交换了网络可达性的信息后,各 BGP 发言人就根据所采用的策略从收到的路由信息中找出到达各 AS 的较好路由

BGP协议特点:

  1. BGP 支持 CIDR,因此 BGP 的路由表也就应当包括目的网络前缀、下一跳路由器,以及到达该目的网络所要经过的各个自治系统序列

  1. 在 BGP 刚刚运行时,BGP 的邻站是交换整个的 BGP 路由表。但以后只需要在发生变化时更新有变化的部分。这样做对节省网络带宽和减少路由器的处理开销都有好处

BGP-4的四种报文:

  1. OPEN(打开) 报文:用来与相邻的另一个BGP发言人建立关系,并认证发送方

  1. UPDATE(更新)报文: 通告新路径或撤销原路径。

  1. KEEPALIVE(保活)报文: 在无UPDATE时,周期性证实邻站的连通性:也作为OPEN的确认

  1. NOTIFICATION(通知) 报文: 报告先前报文的差错:也被用于关闭连接

4.三种路由协议比较

RIP是一种分布式的基于距离向量的内部网关路由选择协议,通过广播UDP报文来交换路由信息

OSPF是一个内部网关协议,要交换的信息量较大,应使报文的长度尽量短,所以不使用传输层协议(如UDP或TCP),而是直接采用IP

BGP是一个外部网关协议,在不同的自治系统之间交换路由信息,由于网络环境复杂,需要保证可靠传输,所以采用TCP

协议

RIP

OSPF

BGP

类型

内部

内部

外部

路由算法

距离-向量

链路状态

路径-向量

传递协议

UDP

IP

TCP

路径选择

跳数最少

代价最低

较好,非最佳

交换结点

和本结点相邻的路由器

网络中的所有路由器

和本结点相邻的路由器

交换内容

当前本路由器知道的全部信息,即自己的路由表

与本路由器相邻的所有路由器的链路状态

首次

整个路由表

非首次

有变化的部分

5.IP组播

IP数据报的三种传输方式:

  1. 单播:单播用于发送数据包到单个目的地,且每发送一份单播报文都使用一个单播IP地址作为目的地址。是一种点对点传输方式

  1. 广播:广播是指发送数据包到同一广播域或子网内的所有设备的一种数据传输方式是一种点对多点传输方式

  1. 组播:当网络中的某些用户需要特定数据时,组播数据发送者仅发送一次数据,借助组播路由协议为组播数据包建立组播分发树,被传递的数据到达距离用户端尽可能近的节点后才开始复制和分发,是一种点对多点传输方式

IP组播地址:IP组播地址让源设备能够将分组发送给一组设备。属于多播组的设备将被分配一个组播组IP地址(一群共同需求主机的相同识),组播地址范围为224.0.0.0~239.255,255.255(D类地址),一个D类地址表示一个组播组。只能用作分组的目标地址。源地址总是为单播地址

IGMP协议与组播路由选择协议:

组播路由协议目的是找出以源主机为根节点的组播转发树

构造树可以避免在路由器之间兜圈子。

对不同的多播组对应于不同的多播转发树:同一个多播组,对不同的源点也会有不同的多播转发树

6.移动IP

定义:移动IP技术是移动结点(计算机/服务器等)以固定的网络IP地址,实现跨越不同网段的漫游功能,并保证了基于网络IP的网络权限在漫游过程中不发生任何改变

专业术语解析:

移动结点:具有永久IP地址的移动设备

归属代理(本地代理):一个移动结点拥有的就“居所”称为归属网络,在归属网络中代表移动节点执行移动管理功能的实体叫做归属代理

外部代理(外地代理):在外部网络中帮助移动节点完成移动管理功能的实体称为外部代理

永久地址 (归属地址/主地址 ):移动站点在归属网络中的原始地址

转交地址(辅地址):移动站点在外部网络使用的临时地址

移动IP通信过程:

A刚进入外部网络:

  1. 在外部代理登记获得一个转交地址,离开时注销

  1. 外地代理向本地代理登记转交地址

B给A发送数据报:

  1. 本地代理截获数据报

  1. 本地代理再封装数据报,新的数据报目的地址是转交地址,发给外部代理(隧道)

  1. 外部代理拆封数据报并发给A

A给B发送数据报:

A用自己的主地址作为数据报源地址,用B的IP地址作为数据报的目的地址。

7.三层设备

区别:

路由器:可以互联两个不同网络层协议的网段

网桥:可以互联两个物理层和链路层不同的网段

集线器:不能互联两个物理层不同的网段

能否隔离冲突域

能否隔离广播域

物理层设备[傻瓜](中继器、集线器)

链路层设备[路人](网桥、交换机)

网络层设备[大佬](路由器)

路由表根据路由选择算法得出的,主要用途是路由选择,总用软件来实现,转发表路由表得来

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

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

相关文章

一动不动是王八?动态内存有话说

文章目录前言动态内存函数介绍mallocfreecallocrealloc柔性数组柔性数组特点柔性数组的优点方便内存释放提高我们的访问速度总结前言 一动不动是王八,出自2014年的春晚,小时候经常喜欢说这句话,那在我们C语言中,我们知道&#xf…

年度征文|一个业余电脑玩家的30年(1992-2022)

《论语为政》:“五十而知天命”。岁月真的是一把刀,一晃已过不惑之年,还有几天就要进入知非之年。不论知非还是知天命,反正是花甲将至而从心所欲了。年少时因某种不合机缘,错与IT界擦肩而过,每每想起就扼腕…

gradel学习+IDEA配置

Gradle的下载 Gradle下载地址如下 https://gradle.org/releases/ 我自己的下载的7.4.2 可以选择下载完整的压缩包,将压缩包解压到自己指定的目录中即可。 Gradle安装 1、配置系统变量 GRADLE_HOME 2、配置环境变量 %GRADLE_HOME%是获取变量名称为GRADLE_HOME的…

项目看板开发经验分享(一)——光伏绿色能源看板

今天新开一个系列,专门介绍近期工作中开发的几个比较酷炫的看板的开发思路与经验分享。第一节我们就来介绍下这个光伏绿色能源看板,整体浏览如下: 那就直接进入正题吧—— 0、可复用组件panel 在讲解各个模块之前,我们先来完成一…

Mybatis 框架下 SQL 注入攻击的 3 种方式

SQL注入漏洞作为WEB安全的最常见的漏洞之一,在java中随着预编译与各种ORM框架的使用,注入问题也越来越少。 新手代码审计者往往对Java Web应用的多个框架组合而心生畏惧,不知如何下手,希望通过Mybatis框架使用不当导致的SQL注入问…

Node.js学习笔记

Node.js学习笔记 浏览器的内核包括两部分核心:DOM渲染引擎、JavaScript解析引擎。脱离浏览器环境也可以运行JavaScript,只要有JavaScript引擎就可以。 Node.js是一个基于Chrome V8引擎的JavaScript运行环境。Node.js内置了Chrome的V8 引擎,…

SpringBoot项目部署

系列文章目录 Spring Boot[概述、功能、快速入门]_心态还需努力呀的博客-CSDN博客 Spring Boot读取配置文件内容的三种方式_心态还需努力呀的博客-CSDN博客 Spring Boot整合Junit_心态还需努力呀的博客-CSDN博客 Spring Boot自动配置--如何切换内置Web服务器_心态还需努力呀…

Open3D SOR滤波(Python版本)

文章目录一、简介二、实现代码三、实现效果参考资料一、简介 SOR滤波过程相对简单,其原理是通过查询点与邻域点集之间的距离统计判断来进行过滤离群点。假设一个点的邻近点集符合正太分布,因此我们可以通过计算出该点到它所有临近点的平均距离meanD和标准…

国内怎么体验openAI chatGPT

怎么体验openAI chatGPT 一,前提 1,先准备好一个gmai的邮箱,注册时要用 2,(懂得都懂) 3,ChatGPT:网址 二,开始注册 1,sign up,用Gmail注册,我…

洛谷P8942 Digital Fortress

题目大意 给定一个区间,构造一个单调不减的序列,使得其前缀异或和与后缀异或和均单调递减,判断这种序列是否存在并输出任意一种解。 思路 暴力 dfs 当然会 TLE,所以我们要仔细分析: ① 在什么情况下异或和能够单调不减&#x…

2023/1/15 JS-原型与原型链

1 什么是原型 原型是Javascript中的继承的基础,JavaScript的继承就是基于原型的继承。每一个JS对象都可以获得自己的原型,通过原型可以共享函数对象和实例对象之间的属性和方法。 原型的出现,就是为了解决 构造函数 的缺点: 每一…

HTB-Shoppy

HTB-Shoppy信息收集开机提权信息收集 22和80。 能扫描出来的东西很杂,但是admin和login可以重点关注。 访问其中之一,能发现是一个登陆界面。 对其进行简单的sql注入测试。输入admin’or11#会出现504超时,判断可能是因为有sql防御措施所致。…

SpringCloud Netflix复习之Zuul

文章目录写作背景Zuul是什么Zuul的核心功能上手实战SpringCloud中Zuul如何使用自定义过滤器配置全局Fallback降级Zuul请求头Ribbon等其他参数配置过滤敏感请求头参数配置开启Ribbon懒加载和Ribbon超时配置开启Hystrix超时配置(一般不配置没啥用)源码部分请求入口ZuulServlet注入…

C++入门--list

目录 list的介绍: list的构造: 遍历: reverse、sort、unique list的模拟实现: 反向迭代器: list与vector的比较: list的介绍: list是序列容器,允许在序列内的任何位置执行O(…

RocketMQ源码(19)—Broker处理DefaultMQPushConsumer发起的拉取消息请求源码【一万字】

基于RocketMQ release-4.9.3,深入的介绍了Broker处理DefaultMQPushConsumer发起的拉取消息请求源码。 此前我们学习了RocketMQ源码(18)—DefaultMQPushConsumer消费者发起拉取消息请求源码。我们知道consumer在发送了拉取消息请求的时候,请求的Code为PUL…

【 JavaScript编程详解 -1 】什么是JavaScript ?

文章目录简介Java与JavaScript的不同Javascrpt可以做什么JavaScript的构成为什么可以在浏览器中运行如何将 JavaScript 代码添加到网站&#xff1f;方法1- \<script\>标签内嵌JavaScript方法1- \<script\>标签引入外部JavaScript文件方法3- 内联 JavaScript编辑器推…

蛇形矩阵(简单明了的方法)

T112524 【数组2】蛇形矩阵 题目来源 AC代码 #include<stdio.h>int main() {int arr[111][111];int n 0;scanf("%d",&n);int temp 0;int sum 1;while(temp<(2*n-2)){for(int i0;i<n;i){for(int j0;j<n;j){if((ij) temp){if(temp%2 0){arr[…

基于FPGA的时间数字转换(TDC)设计(三)

1.多相位TDC计时测试 以下为多相位TDC计时的测试。图1为多相位TDC计时的测试框图,利用信号发生器,产生两路同相位、具有固定延时的脉冲信号,一路作为Start信号,另外一路作为Stop信号。由于分辨率为312.5ps,因此以312.5ps为步进,对Stop信号进行延时,扫描一个周期,通过UA…

红米 12C earth Fastboot 线刷包 root TWRP 刷入magisk recovery卡刷

红米 12C earth Fastboot 线刷包 root TWRP 刷入magisk recovery卡刷 红米 12C (earth) 国行版 Fastboot 线刷包 & Recovery 卡刷包 ROM 红米 12C earth Fastboot 线刷包 root TWRP 刷入magisk recovery卡刷下载 红米 12C 稳定版 Fastboot 线刷包 要安装国行版 红米 12C F…

对笔试使用《剑指offer》吧(第十天)

跟着博主一起刷题 这里使用的是题库&#xff1a; https://leetcode.cn/problem-list/xb9nqhhg/?page1 目录剑指 Offer 62. 圆圈中最后剩下的数字剑指 Offer 64. 求12…n剑指 Offer 65. 不用加减乘除做加法剑指 Offer 62. 圆圈中最后剩下的数字 剑指 Offer 62. 圆圈中最后剩下的…