当前位置: 首页 > article >正文

一、ACWing笔记整理

一、基础算法1.快速排序--不稳定算法思路两个指针从最左最右出发当指向数x时向中间移动若则两指针指向数交换#include iostream using namespace std; const int N 1e6 10; int n; int q[N]; void quick_sort(int q[], int l, int r) { if (l r) return; int x q[l], i l - 1, j r 1;//x可取q[r]或者q[(lr)/2] while (i j) { do i ; while (q[i] x); do j -- ; while (q[j] x); if (i j) swap(q[i], q[j]); } quick_sort(q, l, j);//quick_sort(q, l, i-1);但是这时x不可取q[l]不然会死循环 eg1 2 quick_sort(q, j 1, r);//quick_sort(q, i, r); } int main() { scanf(%d, n); for (int i 0; i n; i ) scanf(%d, q[i]); quick_sort(q, 0, n - 1); for (int i 0; i n; i ) printf(%d , q[i]); return 0; }2.归并排序算法思路a.确定分界点mid(lr)/2 b.归并排序left right c. 合二为一[双指针分别指向两部分的第一即最小值比对两个最小值将更小的放进tmp数组同时此指针向后移动]#includeiostream using namespace std; const int N 1000010; int n; int q[N], tmp[N]; void merge_sort(int q[], int l, int r) { if (l r) return; int mid (lr)/2; merge_sort(q, l, mid), merge_sort(q, mid 1, r); int k 0, i l, j mid 1; while (i mid j r) if (q[i] q[j]) tmp[k ] q[i ]; else tmp[k ] q[j ]; while (i mid) tmp[k ] q[i ]; while (j r) tmp[k ] q[j ]; for (i l, j 0; i r; i , j ) q[i] tmp[j]; } int main() { scanf(%d, n); for (int i 0; i n; i ) scanf(%d, q[i]); merge_sort(q, 0, n - 1); for (int i 0; i n; i ) printf(%d , q[i]); return 0; }3.二分查找3.1 整数二分#include iostream using namespace std; // 整数二分 /* 有单调性一定可以二分 但没有单调性可以二分 二分的本质不是单调性而是边界 第一种二分 FIRST 先找一个mid (lr1) /2 check mid true [mid,r] l mid **如果l取mid则要1 false [l,mid-1] r mid-1 如何考虑用什么模板 先写一个check函数 再考虑如何更新区间 第二种二分 Second mid (lr1) /2 check mid true [l,mid-1] r mid **如果r取mid则不用1 false [mid1,r] l mid1 */ const int N100005; int a[N]; int n,m; int main() { cinnm; for(int i0;in;i) scanf(%d,a[i]); while(m--){ int x; scanf(%d,x); int l0,rn-1; while(lr){ int mid (lr)/2; if(a[mid]x) rmid; else lmid1; } if(a[l]!x)cout-1 -1endl; else { coutl ; int l0,rn-1; while(lr){ int mid(lr1)/2; if(a[mid]x) l mid; else r mid-1; } coutlendl; } } return 0; }4.高精度vector是 C 标准库中的一种动态数组容器它可以根据需要自动调整大小支持在尾部快速添加或删除元素并且能够像普通数组一样通过下标随机访问元素。push_back(val)在末尾添加一个元素。pop_back()删除末尾元素不返回该元素。size()返回当前元素个数。4.1高精度加法#include iostream #include vector #includestring using namespace std; vectorint add(vectorint A, vectorint B) { //为了方便计算让A中保存较长的数字 B中保存较短的数字 if (A.size() B.size()) return add(B, A); //保存结果的数组 vectorint C; //进位开始时是0 int t 0; //依次计算每一位 for (int i 0; i A.size(); i ) { t A[i];//加上 A 的第 i 位上的数字 if (i B.size()) t B[i];//加上 B 的第 i 位上的数字 C.push_back(t % 10); //C 中放入结果 t / 10;//t 更新成进位 } //最后如果进位上有数放进结果数组 if (t) C.push_back(t); return C;//返回结果 } int main() { string a, b;//以字符串形式保存输入的两个整数 vectorint A, B;//保存两个整数的数组 cin a b;//接收输入 for (int i a.size() - 1; i 0; i -- ) A.push_back(a[i] - 0);//倒序存储第一个数 for (int i b.size() - 1; i 0; i -- ) B.push_back(b[i] - 0);//倒序存储第二个数 auto C add(A, B);//auto根据初始化表达式的类型自动推导变量的类型--这里会自动推导成vectorint类型 for (int i C.size() - 1; i 0; i -- ) cout C[i];//倒序输出C中的数字 cout endl; return 0; }4.2高精度减法#include iostream #include vector #includestring using namespace std; // 判断是否有 A B bool cmp(vectorint A, vectorint B) { if (A.size() ! B.size()) return A.size() B.size(); for (int i A.size() - 1; i 0; i--) { if (A[i] ! B[i]) { return A[i] B[i]; } } return true; } // C A - B vectorint sub(vectorint A, vectorint B) { vectorint C; for (int i 0, t 0; i A.size(); i) { t A[i] - t;//后边t是借位的值1/0 if (i B.size()) t - B[i]; C.push_back((t 10) % 10); if (t 0) t 1; else t 0; } while (C.size() 1 C.back() 0) C.pop_back();//去除前导0 return C; } int main() { string a, b; vectorint A, B; cin a b; // a 123456 for (int i a.size() - 1; i 0; i--) A.push_back(a[i] - 0); // A [6, 5, 4, 3, 2, 1] for (int i b.size() - 1; i 0; i--) B.push_back(b[i] - 0); if (cmp(A, B)) { auto C sub(A, B); for (int i C.size() - 1; i 0; i--) printf(%d, C[i]); } else { auto C sub(B, A); printf(-); for (int i C.size() - 1; i 0; i--) printf(%d, C[i]); } return 0; }4.3高精度乘法把b看成整体去做乘法#include iostream #include vector #include string using namespace std; // C A * b vectorint mul(vectorint A, int b) { vectorint C; int t 0; // 进位 for (int i 0; i A.size() || t; i ) { if (i A.size()) t A[i] * b; C.push_back(t % 10); t / 10; } return C; } int main() { string a; int b; cin a b; vectorint A; for (int i a.size() - 1; i 0; i -- ) A.push_back(a[i] - 0); auto C mul(A, b); for (int i C.size() - 1; i 0; i -- ) printf(%d, C[i]); return 0; }4.4高精度除法函数里加了r来传递余数#include iostream #include vector #include algorithm #include string using namespace std; // A / b商是C余数是r vectorint div(vectorint A, int b, int r)//这里必须用r才能把r的值传回main函数 { vectorint C; r 0; for (int i A.size() - 1; i 0; i -- ) { r r * 10 A[i]; C.push_back(r / b); r % b; } reverse(C.begin(), C.end());//用reverse要#include algorithm while (C.size() 1 C.back() 0) C.pop_back(); return C; } int main() { string a; int b; cin a b; vectorint A; for (int i a.size() - 1; i 0; i -- ) A.push_back(a[i] - 0); int r; auto C div(A, b, r); for (int i C.size() - 1; i 0; i -- ) printf(%d, C[i]); cout endl r endl; return 0; }5.前缀和与差分5.1一维前缀和#includeiostream using namespace std; const int N1e510; int n;int m; int q[N];int s[N]; int main(){ cinnm; for(int i1;in;i) scanf(%d,q[i]); s[0]0; for(int i1;in;i){ s[i]s[i-1]q[i]; } int l,r; for(int i1;im;i){ cinlr; printf(%d\n,(s[r]-s[l-1])); } return 0; }5.2二维前缀和#includeiostream using namespace std; const int N1e310; int n;int m;int qq; int q[N][N];int s[N][N]; int main(){ cinnmqq; for(int i1;in;i){ for(int j1;jm;j){ scanf(%d,q[i][j]); } } for(int i1;in;i){ s[i][0]0;s[0][i]0; } for(int i1;in;i){ for(int j1;jm;j){ s[i][j]s[i-1][j]s[i][j-1]q[i][j]-s[i-1][j-1]; } } int x1,x2,y1,y2; for(int i1;iqq;i){ ciny1y2x1x2; printf(%d\n,(s[x1][x2]s[y1-1][y2-1]-s[y1-1][x2]-s[x1][y2-1])); } return 0; }5.3一维差分#includeiostream using namespace std; const int N1e510; int n,m; int q[N];int s[N]; int main(){ cinnm; s[0]q[0]0; for(int i1;in;i){ cinq[i]; s[i]q[i]-q[i-1]; } int l,r,c; for(int i0;im;i){ cinlrc; s[l]c;s[r1]-c; } for(int i1;in;i){ q[i]s[i]q[i-1]; printf(%d ,q[i]); } return 0; }5.4二维差分当于构造矩阵b让原矩阵a是新矩阵b的前缀和#includeiostream using namespace std; const int N1e310; int n, m, qq; int a[N][N], b[N][N]; // 统一标准x代表行y代表列 // 左上角 (x1, y1) 右下角 (x2, y2) void insert(int x1, int y1, int x2, int y2, int c){ b[x1][y1] c; b[x2 1][y1] - c; b[x1][y2 1] - c; b[x2 1][y2 1] c; } int main(){ cin n m qq; // 1. 读取原矩阵并初始化差分矩阵 b for(int i 1; i n; i){ for(int j 1; j m; j){ cin a[i][j]; insert(i, j, i, j, a[i][j]); } } // 2. 处理 qq 次区间修改操作 for(int i 1; i qq; i){ int x1, y1, x2, y2, c; cin x1 y1 x2 y2 c; // 补上 c且按正常顺序读入 insert(x1, y1, x2, y2, c); } // 3. 求二维前缀和将差分矩阵 b 还原为最终答案并输出 for(int i 1; i n; i){ for(int j 1; j m; j){ b[i][j] b[i-1][j] b[i][j-1] - b[i-1][j-1]; cout b[i][j] ; } cout endl; } return 0; }6.双指针算法6.1最长连续不重复子序列#include iostream using namespace std; const int N 100010; int n; int a[N], s[N]; int main() { cin n; for (int i 0; i n; i ) cin a[i]; int res 0; for (int i 0, j 0; i n; i ) { s[a[i]] ; while (s[a[i]] 1) { s[a[j]] -- ; j ; } res max(res, i - j 1); } cout res endl; return 0; }6.2找数组元素目标和#include iostream using namespace std; const int N 100010; int m, n, k; int a[N], b[N]; int main() { cin n m k; for (int i 0; i n; i) cin a[i]; for (int i 0; i m; i) cin b[i]; int i 0; int j m - 1; while(i n j 0){ if(a[i] b[j] k){ cout i j ; return 0; } else if(a[i] b[j] k){ j - 1; } else if(a[i] b[j] k){ i 1; } } return 0; }6.3略7.位运算求n的第k位数字: n k 1返回n的最后一位1lowbit(n) n -n#includeiostream using namespace std; const int N1e510; int n; int lowbit(int x){ return (x (-x)); } int main(){ cinn; while(n--){ int x;int num0; cinx; while(x){ x-lowbit(x); num; } coutnum ; } return 0; }8.离散化#includeiostream #includevector #includealgorithm using namespace std; const int N3e510; typedef pairint,int PII; vectorPII adds,querys; vectorint alls; int q[N],s[N]; int finds(int x){ int l0;int ralls.size()-1; int mid(lr)/2; while(lr){ int mid(lr)/2; if(alls[mid]x) rmid;//有 else lmid1; } return l1;//因为s[]从1开始 而非0 } int main(){ int n,m; cinnm; for(int i0;in;i){ int x,c; cinxc; adds.push_back({x,c}); alls.push_back(x); } for(int i0;im;i){ int l,r; cinlr; querys.push_back({l,r}); alls.push_back(l);alls.push_back(r); } sort(alls.begin(),alls.end()); alls.erase(unique(alls.begin(), alls.end()), alls.end());//unique返回的是末尾重复的第一个元素坐标 for(auto item:adds){ int xfinds(item.first); q[x]item.second; } for(int i1;ialls.size();i){//从i1开始不然s[-1]要越界 s[i]s[i-1]q[i]; } for(auto item:querys){ int lfinds(item.first);int rfinds(item.second); couts[r]-s[l-1]endl; } return 0; }9.区间合并#includeiostream #includevector #includealgorithm//sort using namespace std; const int N3e510; typedef pairint,int PII; int n;vectorPII segs; void merge(vectorPII segs){//必须加不然用不了.first .second以及最后res传不回主函数 vectorPII res; int l-1e9-10,r-1e9-10; for(auto item:segs){ if(ritem.first){ if(l!-1e9-10) res.push_back({l,r}); litem.first;ritem.second; } else{ rmax(r,item.second); } } if(l!-1e9-10) res.push_back({l,r}); segsres; } int main(){ cinn; while(n--){ int l,r; scanf(%d%d,l,r); segs.push_back({l,r}); } sort(segs.begin(),segs.end()); merge(segs); printf(%d,segs.size()); return 0; }

相关文章:

一、ACWing笔记整理

一、基础算法1.快速排序--不稳定算法思路&#xff1a;两个指针从最左最右出发&#xff0c;当指向数<&#xff08;>&#xff09;x时向中间移动&#xff0c;若>&#xff08;<&#xff09;则两指针指向数交换#include <iostream> using namespace std;const int…...

SkeyeVSS平台录像任务调度与设备录像查询机制详解

1. 简介 在基于 GB/T 28181 国家标准构建的视频监控平台中&#xff0c;录像功能是核心业务之一&#xff0c;主要分为两类&#xff1a; 平台侧计划录像&#xff1a;由平台主动发起&#xff0c;通过媒体服务器向设备请求实时流&#xff0c;并在平台侧&#xff08;本地或云存储&am…...

DeEAR语音情感识别入门必看:三维度(唤醒度/自然度/韵律)原理与Gradio界面实操

DeEAR语音情感识别入门必看&#xff1a;三维度&#xff08;唤醒度/自然度/韵律&#xff09;原理与Gradio界面实操 1. 为什么需要语音情感识别 想象一下&#xff0c;当你接到客服电话时&#xff0c;对方的声音是机械冰冷的还是热情自然的&#xff1f;这种差异直接影响沟通效果…...

Qwen3-32B开源模型企业应用:Clawdbot平台审计日志、调用统计、权限分级

Qwen3-32B开源模型企业应用&#xff1a;Clawdbot平台审计日志、调用统计、权限分级 1. 引言&#xff1a;当企业级AI平台遇上开源大模型 想象一下&#xff0c;你的团队正在内部使用一个强大的AI助手&#xff0c;它能回答技术问题、编写代码、甚至帮你分析数据。但问题来了&…...

SkeyeVSS中国标GB28181、流媒体源RTMP/RTSP/HTTP/ONVIF、RTMP推流等协议视频流实时播放流程详解

本文基于 core/app/sev/vss/internal/logic/http/video/stream_play.go 的源码&#xff1a;从参数与设备查询&#xff0c;到按接入协议分支、触发 MS 拉流或 GB28181 Invite&#xff0c;再到返回 StreamResp 与异步处理。 源码地址 点击直达 一、接口入口与请求体 项目说明…...

Anomalib使用

Anomalib 是一个专注于视觉异常检测的开源库&#xff0c;旨在为开发者、研究人员和工业用户提供一站式解决方案。无论是检测生产线上的产品缺陷、监控视频中的异常行为&#xff0c;还是识别医疗影像中的病灶&#xff0c;Anomalib 都能胜任。其设计理念是简单、模块化、高效&…...

PP-DocLayoutV3高算力适配:FP16推理开启后显存降低30%,精度损失<0.5%

PP-DocLayoutV3高算力适配&#xff1a;FP16推理开启后显存降低30%&#xff0c;精度损失<0.5% 文档版面分析是智能文档处理流程中的关键一环&#xff0c;它负责从一张图片中识别出哪里是标题、哪里是正文、哪里是表格或图片。这就像是给文档拍一张X光片&#xff0c;把它的“…...

OpenClaw插件开发入门:为Qwen3-32B镜像编写天气查询技能

OpenClaw插件开发入门&#xff1a;为Qwen3-32B镜像编写天气查询技能 1. 为什么需要自定义技能&#xff1f; 去年冬天&#xff0c;我经常需要同时查看多个城市的天气来规划差旅行程。每次手动打开天气网站、输入城市名、对比数据的过程让我不胜其烦。直到我发现OpenClaw可以通…...

langchain核心组件1-智能体

这里写目录标题简介基础使用静态模型使用动态模型简介 langchain版本 v1.x 在此版本中&#xff0c;langchain可以创建一个智能体 基础使用 我日常使用因为是直接对话&#xff0c;所以基本上只需要以下几个组件 model&#xff1a; 定义智能体大脑&#xff0c;是大语言模型地…...

检索大赛 实验4 文心4.5结果

根据对上述文献的逐一核实&#xff08;通过Google Scholar、会议官网、期刊数据库及作者主页查询&#xff09;&#xff0c;真实存在的文献如下&#xff1a;---### **真实存在的文献**1. **"VulBERTa: A Pre-Trained Language Model for Software Vulnerability Identifica…...

毕业论文查重52%降到8%?实测 PCPASS 智能助手,这届AI降重有点东西!

论文查重&#xff0c;大概是每个毕业生都要经历的“降压药”时刻。 对着满篇通红的查重报告&#xff0c;手动改词、调换语序&#xff0c;忙活了一整天&#xff0c;结果重测还是原地踏步&#xff1f;最近被不少同学催更测评一款呼声很高的神器——PCPASS智能论文助手。今天我就…...

从服务边界到性能边界:理解 ABAP CDS View 里的窄投影及其重要性

结论先讲清楚 在 ABAP CDS 语境里,很多开发者口中的 窄投影,本质上并不是一个独立的官方语法关键字,而是一种建模策略:在 CDS projection view 这一层,只暴露某个具体业务服务真正需要的那一小部分字段、关联、行为和注解,不把底层业务对象里所有能拿到的内容一股脑端出…...

OpenClaw多模型切换:nanobot镜像动态加载不同规格Qwen

OpenClaw多模型切换&#xff1a;nanobot镜像动态加载不同规格Qwen 1. 为什么需要动态切换模型 在本地部署AI助手时&#xff0c;我发现一个痛点&#xff1a;不同任务对模型能力的需求差异很大。简单任务如整理文件、生成周报草稿&#xff0c;用7B参数模型完全够用&#xff1b;…...

Qwen2.5-7B-Instruct惊艳表现:中文古诗创作+格律校验+背景知识延伸

Qwen2.5-7B-Instruct惊艳表现&#xff1a;中文古诗创作格律校验背景知识延伸 1. 项目简介 今天要给大家介绍的是一个让人眼前一亮的大模型应用——基于Qwen2.5-7B-Instruct打造的智能对话服务。这个项目可不是普通的聊天机器人&#xff0c;而是专门为处理复杂文本任务设计的高…...

AI智能文档扫描仪轻量级优势:适用于边缘设备的部署实践

AI智能文档扫描仪轻量级优势&#xff1a;适用于边缘设备的部署实践 1. 为什么轻量级文档扫描在边缘场景中不可替代 你有没有遇到过这样的情况&#xff1a;在客户现场调试工业设备时&#xff0c;需要快速扫描一份维修手册&#xff1b;在仓库盘点时&#xff0c;要即时拍下纸质入…...

浅谈项目运行时,jvm是如何工作的

最近研究了一下项目运行时&#xff0c;jvm是如何工作的&#xff0c;按照自己的理解画的图&#xff0c;一块复习一下有不对的地方&#xff0c;欢迎大家一块讨论...

SDMatte Web化服务运维指南:supervisorctl管理与日志定位技巧

SDMatte Web化服务运维指南&#xff1a;supervisorctl管理与日志定位技巧 1. 服务概述与核心价值 SDMatte是一款专注于高质量图像抠图的AI模型&#xff0c;特别擅长处理复杂边缘和半透明物体的提取任务。该模型已经完成Web化封装&#xff0c;用户可以通过简单的网页操作完成专…...

ButtonIn:嵌入式C++轻量级按键消抖库设计与实践

1. 项目概述ButtonIn 是一个专为嵌入式系统设计的轻量级、高可靠性按键输入封装库&#xff0c;其核心定位是为 ARM Cortex-M 系列微控制器&#xff08;如 STM32、NXP LPC、Renesas RA&#xff09;上的InterruptIn硬件外设提供工业级消抖&#xff08;Debouncing&#xff09;能力…...

阿里蚂蚁Kimi连夜换引擎!混合注意力炸场,456B模型200万token秒吞,API直接打2折

混合注意力&#xff0c;一夜之间从“可选项”变成“必答题”。 阿里、蚂蚁、Kimi、小米&#xff0c;万亿参数集体换引擎&#xff0c;只为回答同一道考题&#xff1a;算力贵到肉疼&#xff0c;模型怎么活下去&#xff1f;三年前&#xff0c;GPT-3用1750亿参数教会世界“大力出奇…...

YOLO X Layout实战:从扫描PDF中自动提取标题与表格的Python实现

办公室最头疼的工作之一就是处理扫描版PDF&#xff1a;不管是合同、审计报告、论文还是发票&#xff0c;扫描版的PDF都是图片&#xff0c;没法复制文本&#xff0c;要提取里面的标题、目录、表格&#xff0c;只能手动敲&#xff0c;几十页的PDF要花几个小时&#xff0c;特别浪费…...

STM32模拟UART实现技术详解

基于STM32的UART模拟实现技术解析1. UART通信基础原理1.1 异步串行通信基础通用异步收发器(UART)作为一种经典的串行通信方式&#xff0c;通过逐位传输实现数据通信。其核心优势在于传输线少、成本低&#xff0c;但相对并行通信速度较慢。异步通信模式下&#xff0c;收发双方的…...

鸿蒙 HarmonyOS 6 | 网络请求超时重试与弱网适配深度解析

文章目录前言一、网络请求的底层机制与超时配置二、超时重试的核心原理与代码实现三、架构优化策略总结前言 弱网环境下的网络波动极易导致应用与服务端断开连接。这不仅影响软件可用性&#xff0c;更是底层技术架构必须解决的核心问题。鸿蒙 6 在网络请求模块进行了底层架构强…...

中考真题资源合集

2024版《万唯中考真题分类》合集 文件大小: 2.2GB内容特色: 2024版万唯中考真题按考点分类&#xff0c;全科覆盖适用人群: 初三学生、教师、家长陪读备考核心价值: 刷透真题&#xff0c;精准查漏补缺&#xff0c;冲刺高分下载链接: https://pan.quark.cn/s/73347caeee74 2026…...

想在职场走得远,必须戒掉弱者心态

想在职场走得远&#xff0c;必须戒掉弱者心态前言抱怨者心态&#xff1a;错永远在外部依赖者心态&#xff1a;永远在被动等待逃避者心态&#xff1a;用无视应对问题如何建立强者心态许多人在职场受挫&#xff0c;习惯性地指责环境、指责他人&#xff0c;唯独不愿审视自身。他们…...

手把手教你用丹青识画:让AI为照片配上惊艳的书法描述

手把手教你用丹青识画&#xff1a;让AI为照片配上惊艳的书法描述 1. 前言&#xff1a;当AI遇见传统书法 想象一下&#xff0c;你随手拍下的风景照片&#xff0c;经过AI处理后竟变成了一幅配有优雅书法题跋的艺术作品。这就是「丹青识画」智能影像系统带来的神奇体验。作为一个…...

Charles抓取WebSocket全链路解析:从配置到实战避坑指南

Charles抓取WebSocket全链路解析&#xff1a;从配置到实战避坑指南 WebSocket协议调试一直是开发者的痛点&#xff0c;传统抓包工具难以解析其长连接特性。本文详解如何通过Charles实现WebSocket请求的捕获与分析&#xff0c;包括SSL证书配置、协议升级拦截等核心步骤&#xf…...

母版设置、讲义母版、模板设置

母版设置、讲义母版、模板设置一. 母版设置1.1 插入母版及版式1.2 重命名母版及版式1.3 版式设置1.4 例题二. 讲义母版2.1 讲义母版设置三. 模板设置3.1 导入模板3.2 例题一. 母版设置 1.1 插入母版及版式 插入母版 插入版式&#xff0c;先点击一下母版 1.2 重命名母版及版…...

华为OD面试-Java、C++、Pyhton等多语言实现-目录

&#x1f468;‍⚕️ 主页&#xff1a; gis分享者 &#x1f468;‍⚕️ 感谢各位大佬 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍⚕️ 收录于专栏&#xff1a;华为OD面试 文章目录一、&#x1f340;2023A卷二、&#x1f340;2023B卷一、&#x1…...

enwork

英语口语考试(Oral English Test)作业要求Choose a topic to make an in-depth oral presentation, your topic shall be closely related to your major, your job or any project you have worked on. take a 5-minute video and submit by the 29th of March, 2026.作业提交…...

[搭建Web漏洞靶场:DVWA在CentOS上的部署]

//DVWA 是一个用来进行安全脆弱性鉴定的Web应用平台&#xff0c;可以手动调整靶机源代码的安全级别&#xff0c;包含暴力破解、命令行注入、跨站请求伪造、文件包含、文件上传、SQL注入、XSS等漏洞。&#xff08;1&#xff09;下载安装包通过网盘分享的文件&#xff1a;DVWA-ma…...