AtCoder Beginner Contest 232(A-G)

A - QQ solver (atcoder.jp)直接按题意模拟即可。

B - Caesar Cipher (atcoder.jp)按题意模拟即可

C - Graph Isomorphism (atcoder.jp)按题意模拟即可

D - Weak Takahashi (atcoder.jp) 一个非常套路的网格dp

E - Rook Path (atcoder.jp)

        (1)题意

                有一个H*W的网格,网格中有一个车初始在(x1,y1)这个位置,高桥操作K次后达到(x2,y2)的方案数是多少,每一次移动可以挪到一行或者这一列的任意一个位置上去,但是不能在原始位置。

        (2)思路

                考虑K不大,我们进行O(K)的dp。

                定义dp[i][0]表示前i步操作操作完后和最终位置行列都不同的方案数

                定义dp[i][1]表示前i步操作操作完后和最终位置列相同的方案数

                定义dp[i][2]表示前i步操作操作完后和最终位置列相同的方案数

                定义dp[i][3]表示前i步操作操作完后和最终位置行列都相同的方案数

                1.首先若第i步操作想要变成行列都相同,则前(i - 1)步一定是行相同或者列相同

                        dp[i][3] = dp[i - 1][2] + dp[i - 1][1]

                2.若第i步操作只要变成行相同,那么前面可能是通过行相同,但第i步走到了不同列,或者是前面i-1步行列都不同走到这行上来了,或者是前面行列都一样,走到不同的列去了。

                        dp[i][2] = dp[i - 1][2] * (w - 2) + dp[i - 1][0] + dp[i - 1][3] * (w - 1)

                3.若第i步操作只要变成列相同,那么前面可能是通过列相同,但第i步走到了不同行,或者是前面i-1步行列都不同走到这列上来了,或者是前面行列都一样,走到不同的行去了。

                        dp[i][1] = dp[i - 1][1] * (h - 2) + dp[i - 1][0] + dp[i - 1][3] * (h - 1)

                4.若第i步操作想要变成行列都不同,那么可能是通过行相同,然后走到了不同行,或者是列相同走到了不同列,或者是行列都不同又走到了行列都不同。

                        dp[i][0] = dp[i - 1][2] * (h - 1) + dp[i - 1][1] * (w - 1) + dp[i - 1][0] * (w - 2) + dp[i - 1][0] * (h - 2)

        (3)代码

#include <bits/stdc++.h>
#define rep(i,z,n) for(int i = z;i <= n; i++)
#define per(i,n,z) for(int i = n;i >= z; i--)
#define PII pair<int,int>
#define fi first
#define se second
#define vi vector<int>
#define vl vector<ll>
#define pb push_back
#define sz(x) (int)x.size()
#define all(x) (x).begin(),(x).end()
using namespace std;
using ll = long long;
const int N = 1e6 + 10;
ll dp[N][4];
const ll mod = 998244353;
void solve()
{ll h,w,k;cin >> h >> w >> k;int x1,y1,x2,y2;cin >> x1 >> y1 >> x2 >> y2;if(x1 == x2 && y1 == y2) dp[0][3] = 1;else if(x1 == x2) dp[0][2] = 1;else if(y1 == y2) dp[0][1] = 1;else dp[0][0] = 1;//3 :行列都相同,2:行相同 1:列相同 0:行列都不同rep(i,1,k) {dp[i][3] = dp[i - 1][2] + dp[i - 1][1];dp[i][2] = dp[i - 1][2] * (w - 2) % mod + dp[i - 1][0] + dp[i - 1][3] * (w - 1) % mod;dp[i][1] = dp[i - 1][1] * (h - 2) % mod + dp[i - 1][0] + dp[i - 1][3] * (h - 1) % mod;dp[i][0] = dp[i - 1][2] * (h - 1) % mod + dp[i - 1][1] * (w - 1) + dp[i - 1][0] * (w - 2) % mod + dp[i - 1][0] * (h - 2) % mod;rep(j,0,3) dp[i][j] %= mod;}cout << dp[k][3];
}
int main()
{ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);int T = 1;// cin >> T;while(T --) solve();return 0;
}

F - Simple Operations on Sequence (atcoder.jp)

        (1)题意

                给你一个长度为N的A序列和一个长度为N的B序列,你每次可以对A的一个元素进行加1或减1,这个操作一次花费X元,你也可以对A的一个元素i进行交换,交换A[i]和A[i + 1],这个操作花费Y元,问你使得A序列变成B序列的最小花费是多少?

        (2)思路

                考虑N不大,我们直接进行状压dp,dp[i]表示i这个点集我已经匹配了多少个A序列的位置,匹配了B的哪些位置需要的最小花费。

                那么考虑转移首先枚举我要放的位置(也就是A未匹配的位置),我们把A[j]这个元素放到z这个位置上去,考虑前面已经放了met个,那么你一定需要交换met次。

                最终输出dp[(1 << N) - 1]即可。

        (3)代码

#include <bits/stdc++.h>
#define rep(i,z,n) for(int i = z;i <= n; i++)
#define per(i,n,z) for(int i = n;i >= z; i--)
#define PII pair<int,int>
#define fi first
#define se second
#define vi vector<int>
#define vl vector<ll>
#define pb push_back
#define sz(x) (int)x.size()
#define all(x) (x).begin(),(x).end()
using namespace std;
using ll = long long;
const int N = 20;
ll dp[1 << N];
int a[N],b[N];
void solve()
{ll n,X,Y;cin >> n >> X >> Y;rep(i,0,n - 1) cin >> a[i];rep(i,0,n - 1) cin >> b[i];memset(dp,0x3f,sizeof(dp));dp[0] = 0;for(int i = 0;i < (1 << n);i ++) {int z = __builtin_popcount(i),met = 0;for(int j = n - 1;j >= 0;j --) {if(!(i >> j & 1)) {dp[i | (1 << j)] = min(dp[i | 1 << j],dp[i] + 1ll * abs(a[j] - b[z]) * X + 1ll * met * Y);}else met ++;}}cout << dp[(1 << n) - 1];
}
int main()
{ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);int T = 1;// cin >> T;while(T --) solve();return 0;
}

G - Modulo Shortest Path (atcoder.jp)

        (1)题意

                给你两个序列A和B,你有一条从i->j的权值为(A[i] + B[j]) % M的边,问你从1走到N的最短路径是多长。

        (2)思路

                考虑暴力,我们建边都要N^2,显然不可行,考虑优化建边。

                对于A序列我们把i向M - A[i]连一条权值为0的边,对于B序列我们把B[i]向i连一条权值为0的边,对于[0,M - 1]把0->1,1->2.....M - 2->M - 1连一条权值为1的边,这样图就变成了这样。

                

        为什么要向M-A[i]连边而不是向A[i]连边呢?我们考虑分类讨论一下,画一下横坐标就行了。

        好,现在我们的建边从N^2变成了2*N+M,显然M太大过不了,那么考虑其实有些边是用不到的,比如说0-1->2->3->4->5,难道我真要一步步跳过去?显然不可能,我们可以直接压缩成0->5。那哪些模数要用到呢,实际上就是我们建边用的M - a[i]和b[i],从小的向大的连一下即可,然后跑一个最短路就做完了。        

        (3)代码

#include <bits/stdc++.h>
#define rep(i,z,n) for(int i = z;i <= n; i++)
#define per(i,n,z) for(int i = n;i >= z; i--)
#define PII pair<int,int>
#define fi first
#define se second
#define vi vector<int>
#define vl vector<ll>
#define pb push_back
#define sz(x) (int)x.size()
#define all(x) (x).begin(),(x).end()
using namespace std;
using ll = long long;
const int N = 6e5 + 10;
vector<PII> e[N];
int a[N],b[N];
ll dis[N];
vector<int> ver;
int get(int x)
{return lower_bound(all(ver),x) - ver.begin() + 1;
}
inline ll dij(int s,int t)
{memset(dis,0x3f,sizeof(dis));dis[s] = 0;priority_queue<pair<ll,int>,vector<pair<ll,int>>,greater<pair<ll,int>>> q;q.push({dis[s],s});while(!q.empty()) {auto [val,u] = q.top();q.pop();for(auto [v,w]: e[u]) {if(dis[v] > val + w) {dis[v] = val + w;q.push({dis[v],v});}}}return dis[t];
}
void solve()
{int n,m;cin >> n >> m;rep(i,1,n) {cin >> a[i];a[i] = (m - a[i]) % m;ver.pb(a[i]);}rep(i,1,n) {cin >> b[i];ver.pb(b[i]);}sort(all(ver));rep(i,1,n) {a[i] = get(a[i]);b[i] = get(b[i]);e[i + sz(ver)].pb({a[i],0});e[b[i]].pb({i + sz(ver),0});}rep(i,1,sz(ver) - 1) {e[i].pb({i + 1,ver[i] - ver[i - 1]});}e[sz(ver)].pb({1,(ver[0] -ver[sz(ver) - 1] + m) % m});cout << dij(1 + sz(ver),n + sz(ver));
}
int main()
{ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);int T = 1;// cin >> T;while(T --) solve();return 0;
}

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

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

相关文章

Python的NumPy库(一)基础用法

NumPy库并不是Python的标准库&#xff0c;但其在机器学习、大数据等很多领域有非常广泛的应用&#xff0c;NumPy本身就有比较多的内容&#xff0c;全部的学习可能涉及许多的内容&#xff0c;但我们在这里仅学习常见的使用&#xff0c;这些内容对于我们日常使用NumPy是足够的。 …

5个适合初学者的初级网络安全工作,网络安全就业必看

前言 网络安全涉及保护计算机系统、网络和数据免受未经授权的访问、破坏和盗窃 - 防止数字活动和数据访问的中断 - 同时也保护用户的资产和隐私。鉴于公共事业、医疗保健、金融以及联邦政府等行业的网络犯罪攻击不断升级&#xff0c;对网络专业人员的需求很高&#xff0c;这并…

Linux系统编程系列之线程池

Linux系统编程系列&#xff08;16篇管饱&#xff0c;吃货都投降了&#xff01;&#xff09; 1、Linux系统编程系列之进程基础 2、Linux系统编程系列之进程间通信(IPC)-信号 3、Linux系统编程系列之进程间通信(IPC)-管道 4、Linux系统编程系列之进程间通信-IPC对象 5、Linux系统…

IPsec_SSL VPN身份鉴别过程简要

一、IPsec VPN身份鉴别&#xff08;参考国密标准《GMT 0022-2014 IPsec VPN技术规范》&#xff09; IKE第一阶段&#xff08;主模式&#xff09; “消息2”由响应方发出&#xff0c;消息中具体包含一个SA载荷&#xff08;确认所接受的SA提议&#xff09;、响应方的签名证书和…

Jmeter排查正则表达式提取器未生效问题

今天在使用Jmeter的时候遇到一个很简单的问题&#xff0c;使用正则表达式提取token一直未生效&#xff0c;原因是正则表达式中多了一个空格。虽然问题很简单&#xff0c;但是觉得排查问题的方法很普适&#xff0c;所以记录下&#xff0c;也希望能够给遇到问题的大家一个参考。 …

制作 3 档可调灯程序编写

PWM 0~255 可以将数据映射到0 75 150 225 尽可能均匀电压间隔

很普通的四非生,保研破局经验贴

推免之路 个人情况简介夏令营深圳大学情况机试面试结果 预推免湖南师范大学面试结果 安徽大学面试结果 北京科技大学笔试面试结果 合肥工业大学南京航空航天大学面试结果 暨南大学东北大学 最终结果一些建议写在后面 个人情况简介 教育水平&#xff1a;某中医药院校的医学信息…

计算机网络(第8版)-第4章 网络层

4.1 网络层的几个重要概念 4.1.1 网络层提供的两种服务 如果主机&#xff08;即端系统&#xff09;进程之间需要进行可靠的通信&#xff0c;那么就由主机中的运输层负责&#xff08;包括差错处理、流量控制等&#xff09;。 4.1.2 网络层的两个层面 4.2 网际协议 IP 图4-4 网…

PyTorch实例:简单线性回归的训练和反向传播解析

文章目录 &#x1f966;引言&#x1f966;什么是反向传播&#xff1f;&#x1f966;反向传播的实现&#xff08;代码&#xff09;&#x1f966;反向传播在深度学习中的应用&#x1f966;链式求导法则&#x1f966;总结 &#x1f966;引言 在神经网络中&#xff0c;反向传播算法…

【Java 进阶篇】JDBC 数据库连接池 C3P0 详解

数据库连接池是数据库编程中常用的一种技术&#xff0c;它可以有效地管理数据库连接&#xff0c;提高数据库访问的性能和效率。在 Java 编程中&#xff0c;有多种数据库连接池可供选择&#xff0c;其中之一就是 C3P0。本文将详细介绍 C3P0 数据库连接池的使用&#xff0c;包括原…

linux内核分析:网络协议栈

从本质上来讲,所谓的建立连接,其实是为了在客户端和服务端维护连接,而建立一定的数据结构来维护双方交互的状态,并用这样的数据结构来保证面向连接的特性。TCP 无法左右中间的任何通路,也没有什么虚拟的连接,中间的通路根本意识不到两端使用了 TCP 还是 UDP。 所谓的连接…

redis持久化与调优

一 、Redis 高可用&#xff1a; 在web服务器中&#xff0c;高可用是指服务器可以正常访问的时间&#xff0c;衡量的标准是在多长时间内可以提供正常服务&#xff08;99.9%、99.99%、99.999%等等&#xff09;。但是在Redis语境中&#xff0c;高可用的含义似乎要宽泛一些&#x…

OpenCV利用Camshift实现目标追踪

目录 原理 做法 代码实现 结果展示 原理 做法 代码实现 import numpy as np import cv2 as cv# 读取视频 cap cv.VideoCapture(video.mp4)# 检查视频是否成功打开 if not cap.isOpened():print("Error: Cannot open video file.")exit()# 获取第一帧图像&#x…

【赠书活动第3期】《构建新型网络形态下的网络空间安全体系》——用“价值”的视角来看安全

目录 一、内容简介二、读者受众三、图书目录四、编辑推荐五、获奖名单 一、内容简介 经过30多年的发展&#xff0c;安全已经深入到信息化的方方面面&#xff0c;形成了一个庞大的产业和复杂的理论、技术和产品体系。 因此&#xff0c;需要站在网络空间的高度看待安全与网络的…

UE5报错及解决办法

1、编译报错&#xff0c;内容如下&#xff1a; Unable to build while Live Coding is active. Exit the editor and game, or press CtrlAltF11 if iterating on code in the editor or game 解决办法 取消Enable Live Coding勾选

企业部署,springboot+vue+vue,Linux上部署mysql与redis,docker中部署nginx,jenkins。完整详细。

企业项目部署全流程笔记 前言 涉及&#xff1a;Linux服务器&#xff0c;docker&#xff0c;Jenkins&#xff0c;nginx&#xff0c;springoot&#xff0c;vue&#xff0c;mysql&#xff0c;redis&#xff0c;git&#xff0c; docker生成容器类型&#xff1a;MySql&#xff0c…

string类的模拟实现(万字讲解超详细)

目录 前言 1.命名空间的使用 2.string的成员变量 3.构造函数 4.析构函数 5.拷贝构造 5.1 swap交换函数的实现 6.赋值运算符重载 7.迭代器部分 8.数据容量控制 8.1 size和capacity 8.2 empty 9.数据修改部分 9.1 push_back 9.2 append添加字符串 9.3 运算符重载…

[学习笔记]ARXML - Data Format

参考AUTOSAR文档&#xff1a; https://www.autosar.org/fileadmin/standards/R22-11/FO/AUTOSAR_TPS_ARXMLSerializationRules.pdfhttps://www.autosar.org/fileadmin/standards/R22-11/FO/AUTOSAR_TPS_ARXMLSerializationRules.pdf 编码 arxml只允许使用UTF-8编码&#xff…

小谈设计模式(19)—备忘录模式

小谈设计模式&#xff08;19&#xff09;—备忘录模式 专栏介绍专栏地址专栏介绍 备忘录模式主要角色发起人&#xff08;Originator&#xff09;备忘录&#xff08;Memento&#xff09;管理者&#xff08;Caretaker&#xff09; 应用场景结构实现步骤Java程序实现首先&#xff…

VC++创建windows服务程序

目录 1.关于windows标准可执行程序和服务程序 2.服务相关整理 2.1 VC编写服务 2.2 服务注册 2.3 服务卸载 2.4 启动服务 2.5 关闭服务 2.6 sc命令 2.7 查看服务 3.标准程序 3.1 后台方式运行标准程序 3.2 查找进程 3.3 终止进程 以前经常在Linux下编写服务器程序…