1.28学习总结

队列:
1.求区间所有后缀最大值的位置(单调队列)
搜索:
1.天下第一(记忆化)
2.拯救oibh总部(DFS+连通性问题)
3.国王的魔镜(递归)
4.回家(BFS+三维的标记)
5.取数游戏(DFS)
6.数的划分(递归)

求区间所有后缀最大值的位置https://www.luogu.com.cn/problem/B3667

题目描述

给定一个长度为 �n 的数列 �a,对于其中每个长度为 �k 的子区间,请你求出这个这个子区间构成的数列的所有后缀最大值的位置个数。

一个下标 �i 是是数列 �b 的后缀最大值下标当且仅当:对于所有的 �<�≤∣�∣i<j≤∣b∣,都有 ��>��bi​>bj​,其中 ∣�∣∣b∣ 表示 �b 的元素个数。

输入格式

第一行是两个整数,依次表示操作次数 �n 和子区间长度 �k。
第二行有 �n 个整数,第 �i 个整数表示 ��ai​。

输出格式

共输出 �−�+1n−k+1 行每行一个整数,按左端点从小到大的顺序依次输出每个子区间构成的数列的后缀最大值位置个数。

输入输出样例

输入 #1复制

5 3
2 1 3 5 4

输出 #1复制

1
1
2

说明/提示

样例 1 解释

第一个子数列:2,1,32,1,3。其中 33 是后缀最大值。
第二个子数列:1,3,51,3,5,其中 55 是后缀最大值。
第三个子数列:3,5,43,5,4,其中 55 和 44 是后缀最大值。

数据规模与约定

对于全部的测试点,保证 1≤�≤�≤1061≤k≤n≤106,1≤��<2641≤xi​<264。

思路:本质上是找单调队列的队内元素个数

#include <bits/stdc++.h>
using namespace std;
unsigned long long  a[1000005];
int main()
{int n,k;cin>>n>>k;for (int i=1;i<=n;++i)cin>>a[i];deque<unsigned long long>q;for (int i=1;i<=n;++i){while (!q.empty() && a[q.back()]<a[i])q.pop_back();if (!q.empty()&& i-q.front()>=k)q.pop_front();q.push_back(i);if (i>=k)cout<<q.size()<<endl;}
}
天下第一https://www.luogu.com.cn/problem/P5635

 

题目背景

天下第一的 cbw 以主席的身份在 8102 年统治全宇宙后,开始了自己休闲的生活,并邀请自己的好友每天都来和他做游戏。由于 cbw 想要显出自己平易近人,所以 zhouwc 虽然是一个蒟蒻,也有能和 cbw 玩游戏的机会。

题目描述

游戏是这样的:

给定两个数 �x,�y,与一个模数 �p。

cbw 拥有数 �x,zhouwc 拥有数 �y。

第一个回合:�←(�+�) mod �x←(x+y)modp。

第二个回合:�←(�+�) mod �y←(x+y)modp。

第三个回合:�←(�+�) mod �x←(x+y)modp。

第四个回合:�←(�+�) mod �y←(x+y)modp。

以此类推....

如果 �x 先到 00,则 cbw 胜利。如果 �y 先到 00,则 zhouwc 胜利。如果 �,�x,y 都不能到 00,则为平局。

cbw 为了捍卫自己主席的尊严,想要提前知道游戏的结果,并且可以趁机动点手脚,所以他希望你来告诉他结果。

输入格式

有多组数据。

第一行:�T 和 �p 表示一共有 �T 组数据且模数都为 �p。

以下 �T 行,每行两个数 �,�x,y。

输出格式

共 �T 行

11 表示 cbw 获胜,22 表示 zhouwc 获胜,error 表示平局。

输入输出样例

输入 #1复制

1 10
1 3

输出 #1复制

error

输入 #2复制

1 10
4 5

输出 #2复制

1

说明/提示

1≤�≤2001≤T≤200。

1≤�,�,�≤100001≤x,y,p≤10000。

思路:用记忆化搜索,不需要管它每一轮的变化,把x,y一直变。谁先到0.谁就赢

#include <bits/stdc++.h>
using namespace std;
short vis[10010][10010];
int t,mod;
int f(int x ,int y)
{if (vis[x][y])return vis[x][y];if (vis[x][y]==-1)return -1;vis[x][y]=-1;if (!x)return 1;if (!y)return 2;int num=(x+y)%mod;vis[x][y]=f(num,(num+y)%mod);return vis[x][y];
}
int main()
{cin>>t>>mod;while (t--){int x,y;cin>>x>>y;int ans=f(x,y);if (ans==-1)cout<<"error"<<endl;else if (ans==1)cout<<ans<<endl;else if (ans==2)cout<<ans<<endl; }
}
拯救oibh总部https://www.luogu.com.cn/problem/P1506

题目背景

oibh 总部突然被水淹没了!现在需要你的救援……

题目描述

oibh 被突来的洪水淹没了,还好 oibh 总部有在某些重要的地方起一些围墙。用 * 号表示,而一个四面被围墙围住的区域洪水是进不去的。

oibh 总部内部也有许多重要区域,每个重要区域在图中用一个 0 表示。

现在给出 oibh 的围墙建设图,问有多少个没被洪水淹到的重要区域。

输入格式

第一行为两个正整数 �,�x,y。

接下来 �x 行,每行 �y 个整数,由 * 和 0 组成,表示 oibh 总部的建设图。

输出格式

输出没被水淹没的 oibh 总部的 0 的数量。

输入输出样例

输入 #1复制

4 5
00000
00*00
0*0*0
00*00

输出 #1复制

1

输入 #2复制

5 5
*****
*0*0*
**0**
*0*0*
*****

输出 #2复制

5

说明/提示

对于 100%100% 的数据,1≤�,�≤5001≤x,y≤500。

思路:考察搜索的连通性问题,以边界为起点,搜索一边,把0全部变成*,最后再找剩余0的个数

#include <bits/stdc++.h>
using namespace std;
char mp[550][550];
int vis[550][550];
int n,m;
void dfs(int x ,int y)
{if (mp[x][y]=='*')return;mp[x][y]='*'; vis[x][y]=1;int dir[4][2]={{0,1},{1,0},{0,-1},{-1,0}};for (int i=0;i<4;++i){int tx=x+dir[i][0],ty=y+dir[i][1];if (tx<0|| ty<0|| tx>n || ty>m)continue;if (mp[tx][ty]=='0' &&vis[tx][ty]==0){dfs(tx,ty);}}vis[x][y]=0;
}
int main()
{cin>>n>>m;for (int i=0;i<n;++i)cin>>mp[i];for (int i = 0; i < n; ++i){dfs(i, 0);dfs(i, m - 1);}for (int j = 0; j < m; ++j){dfs(0, j);dfs(n - 1, j);}int cnt=0;for (int i=0;i<n;++i){for (int j=0;j<m;++j){if (mp[i][j]=='0')cnt++;}}cout<<cnt;
}
国王的魔镜https://www.luogu.com.cn/problem/P2799

题目描述

国王有一个魔镜,可以把任何接触镜面的东西变成原来的两倍——只是,因为是镜子嘛,增加的那部分是反的。比如一条项链,我们用AB来表示,不同的字母表示不同颜色的珍珠。如果把B端接触镜面的话,魔镜会把这条项链变为ABBA。如果再用一端接触的话,则会变成ABBAABBA(假定国王只用项链的某一端接触魔镜)。给定最终的项链,请编写程序输出国王没使用魔镜之前,最初的项链可能的最小长度。

输入格式

只有一个字符串,由大写英文字母组成(字母数<=100000),表示最终的项链。

输出格式

只有一个整数,表示国王没使用魔镜前,最初的项链可能的最小长度。

输入输出样例

输入 #1复制

ABBAABBA

输出 #1复制

2

思路:递归

#include <bits/stdc++.h>
using namespace std;
int f(string &s,int length)
{if (length==1)return length;int idx=length/2-1;string qian=s.substr(0,idx+1);string hou=s.substr(idx+1);reverse(hou.begin(),hou.end());if (qian==hou){return f(qian,length/2);}else {return length;}
}
int main()
{string s;cin>>s;int length=s.length();length=f(s,length);cout<<length;
}

回家https://www.luogu.com.cn/problem/P2802

题目描述

小 H 在一个划分成了 �×�n×m 个方格的长方形封锁线上。 每次他能向上下左右四个方向移动一格(当然小 H 不可以静止不动), 但不能离开封锁线,否则就被打死了。 刚开始时他有满血 66 点,每移动一格他要消耗 11 点血量。一旦小 H 的血量降到 00, 他将死去。 他可以沿路通过拾取鼠标(什么鬼。。。)来补满血量。只要他走到有鼠标的格子,他不需要任何时间即可拾取。格子上的鼠标可以瞬间补满,所以每次经过这个格子都有鼠标。就算到了某个有鼠标的格子才死去, 他也不能通过拾取鼠标补满 HP。 即使在家门口死去, 他也不能算完成任务回到家中。

地图上有五种格子:

0:障碍物。

1:空地, 小 H 可以自由行走。

2:小 H 出发点, 也是一片空地。

3:小 H 的家。

4:有鼠标在上面的空地。

小 H 能否安全回家?如果能, 最短需要多长时间呢?

输入格式

第一行两个整数 �,�n,m, 表示地图的大小为 �×�n×m。

下面 �n 行, 每行 �m 个数字来描述地图。

输出格式

一行, 若小 H 不能回家, 输出 -1,否则输出他回家所需最短时间。

输入输出样例

输入 #1复制

3 3
2 1 1
1 1 0
1 1 3

输出 #1复制

4

说明/提示

对于所有数据,1≤�,�≤91≤n,m≤9。

思路:BFS,但是由于还多了一个血量,所以在建立标记数组的时候应该用三维的,因为可能到达同一个点,但是血量不同

#include <bits/stdc++.h>
using namespace std;
struct Node{int xueliang;int x;int y;int t;
};
int vis[10][10][7];
int mp[10][10];
int main()
{int n,m;cin>>n>>m;int start_x,start_y;for (int i=0;i<n;++i){for (int j=0;j<m;++j){cin>>mp[i][j];if (mp[i][j]==2){start_x=i,start_y=j;}}}queue<Node>q;int dir[4][2]={{0,1},{1,0},{-1,0},{0,-1}};q.push(Node{6,start_x,start_y,0});vis[start_x][start_y][6]=1;while (!q.empty()){Node news=q.front();q.pop();for (int i=0;i<4;++i){int tx=news.x+dir[i][0],ty=news.y+dir[i][1];if (tx<0 || ty<0 || tx>n ||ty>m || vis[tx][ty][news.xueliang-1])continue;if (mp[tx][ty]==1 && news.xueliang>1 ){Node olds=Node{news.xueliang-1,tx,ty,news.t+1};q.push(olds);vis[tx][ty][news.xueliang-1]=1;}else if (mp[tx][ty]==3&& news.xueliang>1){cout<<news.t+1;return 0;}else if (mp[tx][ty]==3&& news.xueliang<=1){continue;}else if (mp[tx][ty]==4 && news.xueliang>1){Node olds=Node{6,tx,ty,news.t+1};vis[tx][ty][6]=1;q.push(olds);}else if (mp[tx][ty]==4 && news.xueliang<=1) {continue;}else if (news.xueliang==0){continue;}}}cout<<-1;return 0;	
}
取数游戏https://www.luogu.com.cn/problem/P1123

题目描述

一个 �×�N×M 的由非负整数构成的数字矩阵,你需要在其中取出若干个数字,使得取出的任意两个数字不相邻(若一个数字在另外一个数字相邻 88 个格子中的一个即认为这两个数字相邻),求取出数字和最大是多少。

输入格式

第一行有一个正整数 �T,表示了有 �T 组数据。

对于每一组数据,第一行有两个正整数 �N 和 �M,表示了数字矩阵为 �N 行 �M 列。

接下来 �N 行,每行 �M 个非负整数,描述了这个数字矩阵。

输出格式

共 �T 行,每行一个非负整数,输出所求得的答案。

输入输出样例

输入 #1复制

3
4 4
67 75 63 10
29 29 92 14
21 68 71 56
8 67 91 25
2 3
87 70 85
10 3 17
3 3
1 1 1
1 99 1
1 1 1

输出 #1复制

271
172
99

说明/提示

样例解释

对于第一组数据,取数方式如下:

[67]7563102929[92]14[21]687156867[91]25[67]29[21]8​75296867​63[92]71[91]​10145625​

数据范围及约定

  • 对于20%20%的数据,1≤�,�≤31≤N,M≤3;
  • 对于40%40%的数据,1≤�,�≤41≤N,M≤4;
  • 对于60%60%的数据,1≤�,�≤51≤N,M≤5;
  • 对于100%100%的数据,1≤�,�≤61≤N,M≤6,1≤�≤201≤T≤20。

思路:DFS加剪枝

#include <bits/stdc++.h>
using namespace std;
int t,n,m;
int mp[8][8];
int dir[8][2]={{0,1},{1,1},{1,0},{1,-1},{0,-1},{-1,-1},{-1,0},{-1,1}};
int vis[8][8];
int maxn=0;
void dfs(int x,int y,int sum)
{if (x==n+1){maxn=max(maxn,sum);return ;}if (y==m+1){dfs(x+1,1,sum);return;}dfs(x,y+1,sum);if (vis[x][y]==0){for (int i=0;i<8;++i){int tx=x+dir[i][0],ty=y+dir[i][1];vis[tx][ty]++;}dfs(x,y+1,sum+mp[x][y]);for (int i=0;i<8;++i){int tx=x+dir[i][0],ty=y+dir[i][1];vis[tx][ty]--;}}
}
int main()
{int t;scanf("%d",&t);while (t--){memset(mp,0,sizeof(mp));memset(vis,0,sizeof(vis));scanf("%d%d",&n,&m);for (int i=1;i<=n;++i){for (int j=1;j<=m;++j){scanf("%d",&mp[i][j]);}}dfs(1,1,0);printf("%d\n",maxn);maxn=0;}
}
数的划分https://www.luogu.com.cn/problem/P1025

题目描述

将整数 �n 分成 �k 份,且每份不能为空,任意两个方案不相同(不考虑顺序)。

例如:�=7n=7,�=3k=3,下面三种分法被认为是相同的。

1,1,51,1,5;
1,5,11,5,1;
5,1,15,1,1.

问有多少种不同的分法。

输入格式

�,�n,k (6<�≤2006<n≤200,2≤�≤62≤k≤6)

输出格式

11 个整数,即不同的分法。

输入输出样例

输入 #1复制

7 3

输出 #1复制

4

说明/提示

四种分法为:
1,1,51,1,5;
1,2,41,2,4;
1,3,31,3,3;
2,2,32,2,3.

思路:DFS,类似全排但是要剪枝

#include <bits/stdc++.h>
using namespace std;
int a[100005];
int k,n,cnt;
void dfs(int minx,int sum,int len)
{if (len==k){if (sum==n){cnt++;}return ;}for (int i=minx;sum+i*(k-len)<=n;++i){dfs(i,sum+i,len+1);}
}
int main()
{cin>>n>>k;dfs(1,0,0);cout<<cnt;
}

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

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

相关文章

AngularJS基础入门文档

引言&#xff1a; AngularJS是一个开源的JavaScript框架&#xff0c;用于构建动态Web应用程序。它提供了一套强大的工具和功能&#xff0c;使开发人员能够更轻松地构建交互性强、响应式的网页应用。本文将为您介绍AngularJS的基本概念和使用方法&#xff0c;帮助您快速入门并掌…

寒假思维训练计划day16 A. Did We Get Everything Covered?

今天更新一道1月27号晚上div2的C题作为素材&#xff0c;感觉用到了我的构造题总结模型&#xff0c;我总结了一系列的模型和例题。 摘要&#xff1a; Part1 定义"边界贪心法" Part2 题意 Part3 题解 Part4 代码 Part5 思维构造题模型和例题 Part1 边界贪心…

【服务器Midjourney】创建部署Midjourney网站

目录 🌺【前言】 🌺【准备】 🌺【宝塔搭建MJ】 🌼1. 给服务器添加端口 🌼2. 使用Xshell连接服务器 🌼3. 安装docker 🌼4. 安装Midjourney程序 🌼5. 绑定域名+申请SSL证书 🌼6. 更新网站

全球唯一使用Python生成双色球和大乐透

生成双色球和大乐透代码&#xff1a; import randomdef gen_union_lotto(nums: int):"""随机生成N个双色球:param nums::return:"""union_list []for i in range(0, nums):data []for data_ in range(0, 6):random_num random.randint(1, 33…

电脑 文件夹内 显示是 文件在一起 ,实际存储硬盘的不同地方?

是的&#xff0c;在电脑上&#xff0c;文件夹内显示在一起的文件可能实际上存储在硬盘的不同物理位置。这是因为现代操作系统使用的是文件系统来管理磁盘上的数据&#xff0c;常见的如NTFS&#xff08;Windows&#xff09;、HFS&#xff08;旧版Mac&#xff09;或APFS&#xff…

【GitHub项目推荐--如何构建项目】【转载】

这是一个 138K Star 的开源项目&#xff0c;这个仓库汇集了诸多优质资源&#xff0c;教你如何构建一些属于自己的东西&#xff0c;内容主要分为增强现实、区块链、机器人、编辑器、命令行工具、神经网络、操作系统等几大类别。 开源地址&#xff1a;https://github.com/danist…

【贪吃蛇:C语言实现】

文章目录 前言1.了解Win32API相关知识1.1什么是Win32API1.2设置控制台的大小、名称1.3控制台上的光标1.4 GetStdHandle&#xff08;获得控制台信息&#xff09;1.5 SetConsoleCursorPosition&#xff08;设置光标位置&#xff09;1.6 GetConsoleCursorInfo&#xff08;获得光标…

滴水逆向三期笔记与作业——02C语言——10 Switch语句反汇编

滴水逆向三期笔记与作业——02C语言——10 Switch语句反汇编 一、Switch语句1、switch语句 是if语句的简写2、break加与不加有什么特点?default语句可以省略吗&#xff1f;3、游戏中的switch语句&#xff08;示例&#xff09;4、添加case后面的值&#xff0c;一个一个增加&…

深兰科技入选亿欧《“制”敬不凡先锋榜·智能机器人Top10》榜单

日前&#xff0c;由亿欧协办的2023工博会工业智能化发展高峰论坛于上海成功举办&#xff0c;会上发布了《2023智能制造&#xff1a;“制”敬不凡先锋者》系列名单。深兰科技凭借在智能机器人开发中的技术创新和模式应用&#xff0c;入选《“制”敬不凡先锋榜——智能机器人Top1…

前端大厂面试题探索编辑部——第二期

目录 题目 单选题1 题解 关于TCP 关于UDP 单选题2 题解 A选项的HTTP是否是无状态协议 B选项的HTTP支持的方法 C选项的关于HTTP的状态码 D选项HTTP协议的传输格式 题目 单选题1 1.以下哪个描述是关于 TCP 和 UDP 的区别&#xff08;&#xff09; A. TCP 是无连接的…

行测-资料:3. 比重、平均数

1、比重 1.1 现期比重★★★ C A&#xff0c;16.63%≈1/6 B C&#xff0c;拆成 50% 和 6.6% ≈ 1/15。 C D 1.2 基期比重★ 数学推导&#xff0c;A&#xff0c;B&#xff0c;A/(1 a)&#xff0c;B / (1 b) A&#xff0c;4 / 9&#xff0c;12 / 27 x 1.14 / 1.18&#xff0c;看…

【大数据】Flink 架构(四):状态管理

Flink 架构&#xff08;四&#xff09;&#xff1a;状态管理 1.算子状态2.键值分区状态3.状态后端4.有状态算子的扩缩容4.1 带有键值分区状态的算子4.2 带有算子列表状态的算子4.3 带有算子联合列表状态的算子4.4 带有算子广播状态的算子 在前面的博客中我们指出&#xff0c;大…

【Java万花筒】数字信号魔法:Java库的魅力解析

从傅立叶到矩阵&#xff1a;数字信号Java库全景剖析 前言 随着数字信号处理在科学、工程和数据分析领域的广泛应用&#xff0c;开发者对高效、灵活的工具的需求日益增长。本文旨在探讨几个与数字信号处理相关的Java库&#xff0c;通过介绍其特点、用途以及与已有库的关系&…

WinRAR压缩包高级技巧:永久设置压缩包单个或批量单独压缩成包并且不内嵌文件夹,解压保留原始时间设置

目录点击跳转&#xff1a;WinRAR压缩包高级技巧&#xff1a;永久设置压缩包单个或批量单独压缩成包并且不内嵌文件夹&#xff0c;解压保留原始时间设置 解压永久设置1 解压保存原始时间 压缩永久设置1 默认压缩成zip手机电脑都通用的格式2 默认压缩文件不多额外嵌套一层文件夹&…

【新书推荐】3.1节 布尔运算

本节内容&#xff1a;布尔运算&#xff0c;又称为逻辑运算或位运算。 ■布尔代数&#xff1a;and与、or或、not非、xor异或&#xff0c;按位运算。 3.1.1 布尔代数 ■布尔代数与二进制的关系 乔治布尔是一位英国小学数学老师&#xff0c;19世纪最重要的数学家之一。出版了《…

《HTML 简易速速上手小册》第2章:HTML 的标签和元素(2024 最新版)

文章目录 2.1 文本格式化标签&#xff08;&#x1f3a9;✨&#x1f4dc; 网页的“时尚搭配师”&#xff09;2.1.1 基础示例&#xff1a;一篇博客的格式化2.1.2 案例扩展一&#xff1a;产品介绍页面2.1.3 案例扩展二&#xff1a;个人简历 2.2 链接和锚点&#xff08;&#x1f6a…

matplotlib实现动画效果

实现正弦波动画 import matplotlib.pyplot as plt from matplotlib.animation import FuncAnimation import numpy as np# 创建图像和轴 fig, ax plt.subplots()# 生成平均分布在0~2*pi之间的100个坐标点 x_data np.linspace(0, 2 * np.pi, 100) # 画出初始图 line, ax.plo…

【漏洞复现】中移铁通禹路由器信息泄露漏洞

Nx01 产品简介 中移禹路由器支持宽带拨号、动态IP和静态IP三种上网模式,一般中国移动宽带的光猫都是智能光猫也就是光猫带路由器功能,中移禹路由器作为二级路由使用。 Nx02 漏洞描述 中移禹路由器ExportSettings处存在信息泄露漏洞&#xff0c;攻击者可以获取后台权限。 Nx03…

sqli.labs靶场(8-17关)

8、第八关&#xff08;布尔盲注&#xff09; id1显示You are in...........&#xff0c;id1单引号不显示&#xff0c;id1 --显示正常 这个应该是单引号闭合&#xff0c;接下来就和第七关差不多上脚本 爆库名长度&#xff1a;id1%27%20and%20length(database()){i}%20-- 爆库…

算法分析(概论)

目录 第一章 概论 1.算法的概念 1.定义 2.算法设计要求 3.算法的特性 4.算法描述 5.数据结构与算法 6.算法设计的基本步骤 2.算法分析 1.计算机资源 2.算法分析 3.评判算法效率的方法 4.算法时间复杂度分析 5.渐进符号 1.大Ο符号 2.大Ω符号 3.大Θ符号 4.三…