[代码随想录Day24打卡] 93.复原IP地址 78.子集 90.子集II
93.复原IP地址
一个合法的IP地址是什么样的:
有3个’.'分割得到4个数,每个数第一个数不能是0,不能含有非法字符,不能大于255。
这个是否属于合法IP相当于一个分割问题,把一串字符串分割成4部分,分别判断每个部分是否合法,如果全部合法就保存结果,否则就return;
回溯三部曲:
- 确定参数和返回值:参数要处理的字符串s,startIndex来防止我们重复分割和pointNum存储当前加的’.‘的个数。我们把path(存储当前的字符串)和result(存储加了’.'符合合法IP条件的字符串的结果列表)定义为了全局变量所以不需要返回值。
- 递归终止条件:if(pointNum==3)说明我们已经加了三个’.',然后直接判断最后一个数字是否合法,如果合法就保存结果,如果不合法就return。
- 单层递归逻辑:我们就是把整体字符串分段,分别判断每一段分割结果是否合法,如果合法就往字符串中加’.',并且递归调用backtracking进行下一次分割如果不合法就直接return不操作。
当前分割的结果:startIndex指明当前循环中开始位置在这个循环过程中是不变的,i不断地向右循环,[startIndex, i]就是当前处理的字符串(就是IP地址中的一段,那段数字,我们只需要判断这段数字是否合法就可以)。
分割标志:startIndex就是相当于分割标志,指明了前一次分割的位置。
下面是C++、JAVA、Python的代码。
class Solution {
private:vector<string> result;bool isValid(const string& s, int start, int end){if(start>end){return false;}if(s[start]=='0' && start != end){//0开头的数字不合法return false;}int num = 0;for(int i = start; i <= end; i++){if(s[i]>'9' || s[i]<'0'){//遇到非法字符不合法return false;}num = num * 10 + (s[i] - '0');if(num>255){//数字大于255不合法return false;}}return true;}void backtracking(string& s, int startIndex, int pointSum){if(pointSum == 3){//对最后一段的合法性进行判断if(isValid(s, startIndex, s.size()-1)){//result.push_back(s);}return;}//递归终止条件for(int i = startIndex; i < s.size(); i++){//单层递归if(isValid(s, startIndex, i)){s.insert(s.begin()+i+1, '.');pointSum += 1;backtracking(s, i+2, pointSum);s.erase(s.begin()+i+1);pointSum-=1;}}}
public:vector<string> restoreIpAddresses(string s) {if (s.size() < 4 || s.size() > 12) return result;backtracking(s, 0, 0);return result;}
};
class Solution {List<String> result = new ArrayList<>();//建立一个列表存储最终结果public List<String> restoreIpAddresses(String s) {backtracking(s, 0, 0);return result;}private void backtracking(String s, int startIndex, int pointNum){if(pointNum == 3){//如果逗号数量为3停止向下递归if(isValid(s, startIndex, s.length()-1)){result.add(s);}return;}for(int i = startIndex; i < s.length(); i++){//单层递归逻辑if(isValid(s, startIndex, i)){//如果合法s = s.substring(0, i+1) + "." + s.substring(i + 1);//在str的后面插入"."pointNum++;backtracking(s, i+2, pointNum);//pointNum--;//回溯s = s.substring(0, i+1) + s.substring(i+2);//回溯删掉逗点,substring一个参数是从beginIndex开始到末尾,有两个参数从 beginIndex 开始到 endIndex 结束前(不包括 endIndex)提取子字符串}else{break;}}}//判断字符串s在左闭右闭区间[start, end]所组成的数字是否合法private Boolean isValid(String s, int start, int end){if(start > end){return false;}//start和end本身就不合法if(s.charAt(start) == '0' && start != end){//0开头的数字不合法return false;}int num = 0;//这个是存储从字符串变成数字的数字for(int i = start; i <= end; i++){//判断每个字符的合法性if(s.charAt(i) > '9' || s.charAt(i)<'0'){return false;}num = num*10 + (s.charAt(i)-'0');//这个就是计算当前的数字if(num > 255){//如果大于255了不合法return false;}}return true;}
}
class Solution(object):def __init__(self):self.result = []def restoreIpAddresses(self, s):""":type s: str:rtype: List[str]"""if(len(s)<4 or len(s)>12):return self.resultself.backtracking(s, 0, 0)return self.resultdef backtracking(self, s, startIndex, pointNum):#递归终止条件if(pointNum == 3):if(self.isValid(s, startIndex, len(s)-1)):self.result.append(s)#如果合法就存入for i in range(startIndex, len(s)):if(self.isValid(s, startIndex, i)):s = s[:i+1]+'.'+s[i+1:]pointNum+=1#往字符串中加入一个点self.backtracking(s, i+2, pointNum)s = s[:i+1] + s[i+2:]pointNum -= 1#回溯def isValid(self, s, start, end):#判断所给字符的合法性,左闭右闭区间#首先判断传入的参数是否合法if(start > end):return False#判断是否开头有0if s[start] == '0' and start!=end:return Falsenum = 0#这个是存储当前这个子串对应的数值的for i in range(start, end+1):if s[i]>'9' or s[i]<'0':return False #判断每个字符是否合法num = num*10 + int(s[i])if(num > 255):return False#超出255非法return True
参考文章
- https://programmercarl.com/0093.%E5%A4%8D%E5%8E%9FIP%E5%9C%B0%E5%9D%80.html
78.子集
遍历这个树的时候,把所有节点都记录下来,就是要求的子集集合。
注意:这个题目时每个节点的结果都要保存,不是只保存叶子节点。其他的和组合差不多。
回溯三部曲:
1. 确定参数和返回值:参数就是数组nums和startIndex指示之前使用了那些元素,防止重复取数。我们把path金额result定义为全局变量,所以不需要返回值。
2. 遍历终止条件:startIndex>= nums.size() return;就是如果startIndex超出了数组的范围就停止递归。
单层递归的逻辑:i从startIndex到nums.size()遍历,每次遍历都把nums[i]当前元素加入到path当前结果中,然后backtracking()继续下层递归,然后path.pop_back()回溯。
class Solution {
private:vector<int> path;vector<vector<int>> result;void backtracking(vector<int>& nums, int startIndex){result.push_back(path);if(startIndex>= nums.size()) return;//递归终止条件for(int i = startIndex; i < nums.size(); i++){path.push_back(nums[i]);backtracking(nums, i+1);path.pop_back();}return;}
public:vector<vector<int>> subsets(vector<int>& nums) {backtracking(nums, 0);return result;}
};
class Solution {List<Integer> path = new LinkedList<>();List<List<Integer>> result = new ArrayList<>();public void backtracking(int[] nums, int startIndex){result.add(new ArrayList<>(path));if(startIndex>=nums.length){return;//递归终止条件}for(int i=startIndex; i < nums.length; i++){path.add(nums[i]);backtracking(nums, i+1);path.removeLast();}}public List<List<Integer>> subsets(int[] nums) {backtracking(nums, 0);return result;}
}
class Solution(object):def __init__(self):self.result = []self.path = []def backtracking(self, nums, startIndex):self.result.append(list(self.path))#别忘了这个加list为了就是不指向同一个地址if(startIndex>=len(nums)):returnfor i in range(startIndex, len(nums)):self.path.append(nums[i])#存入元素self.backtracking(nums, i+1)self.path.pop()def subsets(self, nums):""":type nums: List[int]:rtype: List[List[int]]"""self.backtracking(nums, 0)return self.result
参考文章
- https://programmercarl.com/0078.%E5%AD%90%E9%9B%86.html
90.子集II
这个就是子集和组合Ⅱ的应用。
秒了。
注意:
- 对于有重复元素的题目,要去重,先排序。
- 设置used数组来判断时树枝还是树层。每个语言怎么定义要清楚。
- 保存结果的时候要根据每个语言,JAVA和Python都是需要处理一下path再加入到result中,不然result中的元素都指向同一个位置,最后结果都[]
- 去重的两行代码要记住。
回溯三部曲:
- 确定参数和返回值:参数时数组nums和startIndex,返回值为None。
- 递归终止条件:看startIndex是否越界,如果越界就直接返回。没有也可以,因为后面for循环也会因为startIndex越界不运行直接return。
- 单层递归逻辑:加入去重的两行代码if(i>0 && nums[i]==nums[i-1] && used[i-1]==0)continue;(直接跳过,到不是重复的数,不是break,break会漏掉重复数字之后的所有的数字)然后把当前数字放到path中,更新used使当前索引的位置used[i]=true,然后backtracking()递归处理下一个数,path.pop(),used[i]=false回溯一下。
class Solution {
private:vector<int> path;vector<vector<int>> result;void backtracking(vector<int>& nums, int startIndex, vector<bool> used){result.push_back(path);//想一下递归的终止条件// if(startIndex >= nums.size()) return;for(int i = startIndex; i < nums.size(); i++){if(i>startIndex && nums[i]==nums[i-1] && used[i-1]==0){continue;//跳过重复元素}path.push_back(nums[i]);used[i] = true;backtracking(nums, i+1, used);used[i] = false;path.pop_back();}}
public:vector<vector<int>> subsetsWithDup(vector<int>& nums) {vector<bool> used(nums.size(), false);sort(nums.begin(), nums.end());backtracking(nums, 0, used);return result;}
};
class Solution {List<Integer> path = new LinkedList<>();List<List<Integer>> result = new ArrayList<>();public void backtracking(int[] nums, int startIndex, boolean[] used){result.add(new ArrayList<>(path));//想想递归终止条件if(startIndex>=nums.length) return;for(int i = startIndex; i< nums.length; i++){if(i>0 && nums[i] == nums[i-1] && used[i-1] == false){continue;}path.add(nums[i]);used[i] = true;backtracking(nums, i+1, used);used[i] = false;path.removeLast();}}public List<List<Integer>> subsetsWithDup(int[] nums) {boolean[] used = new boolean[nums.length];Arrays.fill(used, false);Arrays.sort(nums);backtracking(nums, 0, used);return result;}
}
class Solution(object):def __init__(self):self.result = []self.path = []def backtracking(self, nums, startIndex, used):self.result.append(list(self.path))if(startIndex>=len(nums)):#递归终止条件也可以不写returnfor i in range(startIndex, len(nums)):if(i>startIndex and nums[i] == nums[i-1] and not used[i-1]):continue#去重self.path.append(nums[i])used[i] = Trueself.backtracking(nums, i+1, used)used[i] = Falseself.path.pop()def subsetsWithDup(self, nums):""":type nums: List[int]:rtype: List[List[int]]"""nums.sort()#别忘了排序used = [False]*len(nums)self.backtracking(nums, 0, used)return self.result
参考文章
- https://programmercarl.com/0090.%E5%AD%90%E9%9B%86II.html
相关文章:
[代码随想录Day24打卡] 93.复原IP地址 78.子集 90.子集II
93.复原IP地址 一个合法的IP地址是什么样的: 有3个’.分割得到4个数,每个数第一个数不能是0,不能含有非法字符,不能大于255。 这个是否属于合法IP相当于一个分割问题,把一串字符串分割成4部分,分别判断每…...
去哪儿大数据面试题及参考答案
Hadoop 工作原理是什么? Hadoop 是一个开源的分布式计算框架,主要由 HDFS(Hadoop 分布式文件系统)和 MapReduce 计算模型两部分组成 。 HDFS 工作原理 HDFS 采用主从架构,有一个 NameNode 和多个 DataNode。NameNode 负责管理文件系统的命名空间,维护文件和目录的元数据信…...
controller中的参数注解@Param @RequestParam和@RequestBody的不同
现在controller中有个方法:(LoginUserRequest是一个用户类对象) PostMapping("/test/phone")public Result validPhone(LoginUserRequest loginUserRequest) {return Result.success(loginUserRequest);}现在讨论Param("login…...
排序算法思维导图
冒泡排序 def bubble_sort(alist):j 0while j < len(alist):i 0while i < len(alist) - 1:if alist[i] > alist[i1]:alist[i], alist[i1] alist[i1], alist[i]i 1j 1li [34,556,235,7,56,45,63,35,23,4,875] bubble_sort(li) print(li) 选择排序 def select_s…...
ZYNQ试用于哪些场景
ZYNQ系列SoC(System on Chip)由于其独特的处理器与FPGA(可编程逻辑)集成设计,非常适合应用于多种需要高性能、灵活性和低功耗的场景。 以下是一些ZYNQ特别适用的场景: 嵌入式系统:ZYNQ的ARM处理…...
【03】Selenium+Python 八种定位元素方法
操作元素,需要先查找定位到对应的元素。 查找单个元素:driver.find_element() 返回是一个web element 对象 查找多个元素:driver.find_elements() 返回是一个list对象 By 是 Selenium 中一个非常重要的类,用于定位网页元素。 使…...
Java 自动资源管理(Auto Resource Management)详解
Java 自动资源管理(Auto Resource Management)详解 在Java编程中,资源的正确管理是开发过程中一个非常重要的环节。如果资源(如文件、数据库连接、网络连接等)未被正确释放,可能会导致资源泄漏,…...
IT运维专家给年轻人一些职业上的建议
运维工作在现代企业中是非常重要的一环,保证系统的稳定性、可用性以及安全性对企业的正常运营至关重要。以下是我给年轻人的一些职业发展建议,希望能够帮助你们在运维领域找到方向并取得成功。 1. 夯实基础,扎实技术功底 精通操作系统与网络:运维工作需要深入理解操作系统…...
视图查询中投影裁剪规则的原理和解析 | OceanBase 查询优化
背景 在SQL查询中使用视图查询时,执行中可能会产生的较多的中间结果集。为了优化这类查询的执行,OceanBase 引入了投影裁剪规则。能够识别出父查询中未实际使用的列,并将这些列从视图查询的select列表中剔除,进而提升整体查询的性…...
利用Nginx在服务器上部署你的第一个静态页面
文章目录 序言Nginx常用功能1. 反向代理2.负载均衡轮询加权轮询IP_Hash Nginx配置文件结构安装并部署你的静态网页1. 安装(懒人直接看3)2.查看配置文件3.编写或放入自己的静态页面文件 序言 首先我们先来认识一下什么是Nginx源码 官网 Nginx (engine x) 是一个高性能的HTTP和…...
【拥抱AI】RAG如何通过分析反馈、识别问题来提高命中率
分析用户反馈并识别问题是持续优化RAG系统的重要步骤。这不仅可以帮助你了解系统的当前表现,还可以指导未来的改进方向。直接进入正题, 1. 收集用户反馈 方法 问卷调查:设计问卷,让用户填写他们对系统输出的满意度、易用性等方…...
内核模块签名验证
安装内核模块报错 今天在调试地平线 J6 板子时,安装自己编译的内核模块报错 roothobot:/tmp# insmod hobot_eth_j6.ko insmod: ERROR: could not insert module hobot_eth_j6.ko: Key was rejected by service前两天刚在 x86 电脑上解决过这个问题,参…...
C++模板(入门)
文章目录 泛型编程函数模板函数模板的概念函数模板格式函数模板的原理函数模板的实例化隐式实例化显示实例化模板参数的匹配 类模板为什么有类模板类模板的定义格式类模板的实例化Stack模板类的简单实现(不涉及深拷贝) 模板的注意问题模板不支持分离编译…...
如何在Python中进行数学建模?
数学建模是数据科学中使用的强大工具,通过数学方程和算法来表示真实世界的系统和现象。Python拥有丰富的库生态系统,为开发和实现数学模型提供了一个很好的平台。本文将指导您完成Python中的数学建模过程,重点关注数据科学中的应用。 数学建…...
C++优质学习资源汇总
1 学懂C语言-C核心编程精讲 学懂C语言-C核心编程精讲 该课程基本把面试所需要的C常用的网络等教程均进行讲解,满足基本需求...
心情追忆:构建支付模块的五个基本接口设计
之前,我独自一人开发了一个名为“心情追忆”的小程序,旨在帮助用户记录日常的心情变化及重要时刻。我从项目的构思、设计、前端(小程序)开发、后端搭建到最终部署。经过一个月的努力,通过群聊分享等方式,用…...
数据库导论
data 数据是数据库中存储的基本数据,描述事物的符号称为数据。 DB 数据库是长期存储在计算机内,有组织,可共享的大量数据的集合。数据库中的数据按照一定的数据模型组织,描述和存储,具有较小的冗余度,较…...
echarts使用示例
柱状图折线图 折柱混合:https://echarts.apache.org/examples/zh/editor.html?cmix-line-bar option {title:{show: true},tooltip: {trigger: axis,axisPointer: {type: cross,crossStyle: {color: #999}}},toolbox: {feature: {dataView: { show: true, readOnl…...
选修课(Java Python JS C++ C )
题目描述 现有两门选修课,每门选修课都有一部分学生选修,每个学生都有选修课的成绩,需要你找出同时选修了两门选修课的学生,先按照班级进行划分,班级编号小的先输出,每个班级按照两门选修课成绩和的降序排序,成绩相同时按照学生的学号升序排序。 输入描述 第一行为第…...
《解锁 C++数据读写秘籍:赋能人工智能训练》
在人工智能蓬勃发展的时代,数据无疑是驱动模型学习与成长的核心燃料。而 C作为一门高性能编程语言,在处理人工智能训练所需数据集的读取与写入时,有着独特的优势与关键作用。高效地运用 C进行数据操作,能够显著加速训练进程&#…...
23种设计模式-外观(Facade)设计模式
文章目录 一.什么是外观设计模式?二.外观设计模式的特点三.外观设计模式的结构四.外观设计模式的优缺点五.外观设计模式的 C 实现六.外观设计模式的 JAVA 实现七.代码解析八.总结 类图: 外观设计模式类图 一.什么是外观设计模式? 外观设计模…...
ReactPress(阮一峰推荐工具):一款基于Next.js的免费开源博客CMS系统
ReactPress Github项目地址:https://github.com/fecommunity/reactpress 欢迎Star。 此项目是用于构建博客网站的,包含前台展示、管理后台和后端。 此项目是基于 React antd NestJS NextJS MySQL 的,项目已经开源,项目地址在 …...
什么是缓存击穿?如何避免之布隆过滤器
缓存击穿(Cache Penetration)是分布式系统和缓存使用中的一个常见问题,布隆过滤器在解决缓存击穿问题时非常有用。接下来我会介绍缓存击穿的概念以及布隆过滤器在解决该问题中的应用。 什么是缓存击穿? 缓存击穿是指当大量的客户…...
React 第八节组件生命周期钩子-类式组件,函数式组件模拟生命周期用法
概述 React组件的生命周期可以分为三个主要阶段: 挂载阶段(Mounting):组件被创建,插入到DOM 树的过程; 更新阶段(Updating):是组件中 props 以及state 发生变化时&#…...
java虚拟机——如何排查jvm问题
在项目中排查JVM问题是一个系统性的过程,涉及到多个工具和方法。以下是一些常见的步骤和工具,可以帮助你有效地诊断和解决JVM相关的问题: 1. 监控和日志 日志分析 JVM日志:启用JVM的日志记录功能,查看垃圾收集日志、…...
Altium Designer PCB设计检查工具1
此工具最大的特点是不需要联网,完全使用本地的计算资源即可实现检查统计操作,可用于不能联网的应用场景中。此工具支持多种计算加速方法,支持调用CUDA显卡进行数据处理,此功能需要计算机安装Matlab 2016以上版本,并需要…...
统计词频
目标:统计词频 从文件1.txt ,读取内容,保存在一个字符串中统计字符串中,每个单词出现的频率对结果进行排序把最后的结果写入一个新的文件 import java.io.PrintWriter import scala.io.Source//知识点: //1.字符串&a…...
串,数组,广义表相关知识点
串 一.串的储存 1.基本概念 2.顺序储存 3.链式储存 二. 串的模式匹配算法 1.BF算法 将主串的第pos个字符和模式的第一个字符比较, 若相等,继续逐个比较后续字符; 若相等,继续逐个比较后续字符; 若不等,…...
Leetcode 131 Palindrome Partition
题意 把一个字符串分割成多个回文字符串的partition,返回所有的可能partion 链接 https://leetcode.com/problems/palindrome-partitioning/description/ 思考 这只是dfs套了一个回文问题 题解 dfs每次截取一段字符串,判断是否是回文 退出条件是遍…...
git使用文档手册
创建一个本地代码工作空间,比如这里使用test目录作为工作目录 针对仓库地址 http://192.168.31.125:9557/poxiaoai-crm/project-crm.git。 1. 安装 Git 确保您的系统已经安装了 Git。如果未安装,请根据操作系统访问 Git 官网 下载并安装。 验证安装 …...
开发需求总结19-vue 根据后端返回一年的数据,过滤出符合条件数据
需求描述: 定义时间分界点:每月26号8点,过了26号8点则过滤出data数组中符合条件数据下个月的数据,否则过滤出当月数据 1.假如现在是2024年11月14日,那么过滤出data数组中日期都是2024-11月的数据; 2.假如…...
android 安全sdk相关
前述 在网上有看到许多android安全sdk相关的内容,有重复的也有比较新鲜的内容,这里做一个整体的合集,以及后续又看到一些比较新的东西会一起放在这里。 android内sdk目前可以分为以下几个部分(有一些部分可能会存在一些重合&#…...
ChemBench—— 探索大语言模型在化学领域的新基准框架是否胜过化学专家
概述 大规模语言模型是一种机器学习模型,通过学习大量文本来生成文本。这些模型的能力正在迅速提高,现在已经可以通过美国国家医学考试。它们还可以与网络搜索和合成规划器等工具结合使用,自主设计化学反应和进行实验。 一些人认为这些模型…...
[SWPUCTF 2021 新生赛]Do_you_know_http
访问告诉我们要用WLLM 浏览器模式访问 import requestsurl http://node7.anna.nssctf.cn:23148/hello.php # 替换为题目提供的URL headers {User-Agent: WLLM } response requests.get(url, headersheaders) print(response.text)import requestsurl http://node7.anna.n…...
Flink--API 之 Source 使用解析
目录 一、Flink Data Sources 分类概览 (一)预定义 Source (二)自定义 Source 二、代码实战演示 (一)预定义 Source 示例 基于本地集合 基于本地文件 基于网络套接字(socketTextStream&…...
vscode可以编译通过c++项目,但头文件有红色波浪线的问题
1、打开 VSCode 的设置,可以通过快捷键 Ctrl Shift P 打开命令面板,然后搜索并选择 “C/C: Edit Configurations (JSON)” 命令,这将在 .vscode 文件夹中创建或修改 c_cpp_properties.json 文件 {"configurations": [{"name…...
CTF之密码学(培根密码)
培根密码,又名倍康尼密码(Bacons cipher),是由法兰西斯培根发明的一种隐写术,属于密码学领域的一种替换密码。以下是关于培根密码的详细介绍: 一、原理 培根密码本质上是一种二进制密码,但它没…...
摄像头原始数据读取——V4L2(mmap模式,V4L2_MEMORY_MMAP)
摄像头原始数据读取——V4L2(mmap模式,V4L2_MEMORY_MMAP) 内存映射模式,是将设备在内核态申请的用于存储视频数据的物理内存映射到用户空间,使得用户应用程序可以直接访问和操作设备数据物理内存,避免了数据的拷贝。因此采集速度较快&#x…...
Ubuntu20.04下安装Matlab2018
Ubuntu20.04下安装Matlab2018 首先需要下载三个文件 挂载第一个镜像文件 先进入到终端,在空白处点击在终端打开 然后输入以下两个命令: mkdir ~/matlab //用户主目录下新建文件夹 matlab sudo mount -o loop Matlab911R2021b_Lin64.iso ~/matlab //将…...
如何做好一份技术文档?
成长路上不孤单😊😊😊😊😊😊 【14后😊///C爱好者😊///持续分享所学😊///如有需要欢迎收藏转发///😊】 今日分享关于技术文档写作的相关内容! 关…...
GitHub上如何创建文件夹及上传文件
GitHub上如何创建文件夹_github如何添加文件夹-CSDN博客 然后在对应的文件夹下上传文件即可 可以一个一个添加或一次性拖进去,但一次不能超过100个文件。...
GESP C++等级考试 二级真题(2024年9月)
若需要在线模拟考试,可进入题库中心,在线备考,检验掌握程度: https://www.hixinao.com/tidan/exam-157.html?time1732669362&sid172&index1...
Web 表单开发全解析:从基础到高级掌握 HTML 表单设计
文章目录 前言一、什么是 Web 表单?二、表单元素详解总结前言 在现代 Web 开发中,表单 是用户与后端服务交互的重要桥梁。无论是用户登录、注册、搜索,还是提交反馈,表单都无处不在。在本文中,我们将从基础入手,全面解析表单的核心知识点,并通过示例带你轻松掌握表单开…...
SpringBoot生成顺序规则编号-查询数据库方式实现
先说编号规则: 前缀yyyyMMdd5位序号(00001,00002.......) 首先说说思路: 首先是查询数据库中编号的最大值是多少----->没有数据直接生成一个新的从00001开始----->存在编号就直接截取编号的后5位----->序号1 为了可以…...
【大数据学习 | Spark-Core】RDD的五大特性(包含宽窄依赖)
分析一下rdd的特性和执行流程 A list of partitions 存在一系列的分区列表A function for computing each split 每个rdd上面都存在compute方法进行计算A list of dependencies on other RDDs 每个rdd上面都存在一系列的依赖关系Optionally, a Partitioner for key-value RDDs…...
docker离线安装linux部分问题整理
0:离线安装docker过程命令 echo $PATH tar -zxvf docker-26.1.4.tgz chmod 755 -R docker cp docker/* /usr/bin/ root 权限 vim /etc/systemd/system/docker.service --------- [Unit] DescriptionDocker Application Container Engine Documentationhttps://docs.do…...
shell(5)字符串运算符和逻辑运算符
声明! 学习视频来自B站up主 泷羽sec 有兴趣的师傅可以关注一下,如涉及侵权马上删除文章,笔记只是方便各位师傅的学习和探讨,文章所提到的网站以及内容,只做学习交流,其他均与本人以及泷羽sec团队无关&#…...
容器和它的隔离机制
什么是容器和它的隔离机制? 容器 是一种轻量化的虚拟化技术,它允许多个应用程序共享同一个操作系统(OS)内核,同时为每个应用程序提供自己的运行环境。容器通过利用 Linux 的内核功能(如 Namespaces 和 Cgr…...
【Flink-scala】DataStream编程模型之 窗口的划分-时间概念-窗口计算程序
DataStream编程模型之 窗口的划分-时间概念-窗口计算程序 1. 窗口的划分 1.1 窗口分为:基于时间的窗口 和 基于数量的窗口 基于时间的窗口:基于起始时间戳 和终止时间戳来决定窗口的大小 基于数量的窗口:根据固定的数量定义窗口 的大小 这…...
DVWA靶场通过——文件上传漏洞
File Upload漏洞 它允许攻击者通过上传恶意文件来执行任意代码、窃取数据、获取服务器权限,甚至完全控制服务器。为了防止文件上传漏洞,开发者需要对文件上传过程进行严格的验证和处理。 1. 文件上传漏洞概述 文件上传漏洞发生在Web应用程序允许用户通过…...