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.mzph.cn/news/95185.shtml

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

相关文章

探秘前后端开发世界:猫头虎带你穿梭编程的繁忙街区,解锁全栈之路

&#x1f337;&#x1f341; 博主猫头虎 带您 Go to New World.✨&#x1f341; &#x1f984; 博客首页——猫头虎的博客&#x1f390; &#x1f433;《面试题大全专栏》 文章图文并茂&#x1f995;生动形象&#x1f996;简单易学&#xff01;欢迎大家来踩踩~&#x1f33a; &a…

【Java】接口 interface

目录 概述 示例代码&#xff1a; 接口成员访问特点 示例代码&#xff1a; 概述 什么是接口 接口就是一种公共的规范标准&#xff0c;只要符合规范标准&#xff0c;大家都可以调用。 Java 中的接口更多的体现在对行为的抽象&#xff01; 1. 接口 用关键字 interface 修饰 pub…

从零手搓一个【消息队列】创建核心类, 数据库设计与实现

文章目录 一、创建核心类1, 交换机2, 交换机类型3, 队列4, 绑定5, 交换机转发 & 绑定规则6, 消息7, 消息属性 二、数据库设计1, 使用 SQLite2, 使用 MyBatis2.1, 创建 Interface2.2, 创建 xml 文件 三、硬盘管理 -- 数据库1, 创建 DataBaseManager 类2, init() 初始化数据库…

算法题系列10·最长公共前缀

目录 题目描述 思路 实现 题目描述 编写一个函数来查找字符串数组中的最长公共前缀。如果不存在公共前缀&#xff0c;返回空字符串 ""。示例 1&#xff1a; 输入&#xff1a;strs ["flower","flow","flight"] 输出&#xff1a;&qu…

LabVIEW开发教学实验室自动化INL和DNL测试系统

LabVIEW开发教学实验室自动化INL和DNL测试系统 如今&#xff0c;几乎所有的测量仪器都是基于微处理器的设备。模拟输入量在进行数字处理之前被转换为数字量。对于参加电气和电子测量课程的学生来说&#xff0c;了解ADC以及如何欣赏其性能至关重要。ADC的不确定性可以根据其传输…

蓝桥杯每日一题2023.10.5

3420. 括号序列 - AcWing题库 题目描述 题目分析 对于这一我们需要有前缀知识完全背包 完全背包的朴素写法&#xff1a; #include<bits/stdc.h> using namespace std; const int N 1010; int n, m, v[N], w[N], f[N][N]; int main() {cin >> n >> m;fo…

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

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

华为OD七日集训第6期 十一特辑 - 按算法分类,由易到难,循序渐进,玩转OD

目录 专栏导读华为OD机试算法题太多了&#xff0c;知识点繁杂&#xff0c;如何刷题更有效率呢&#xff1f; 一、逻辑分析二、数据结构1、线性表① 数组② 双指针 2、map与list3、优先队列4、滑动窗口5、二叉树6、并查集7、栈 三、算法1、基础算法① 贪心算法② 二分查找③ 分治…

OpenCV 15(SIFT/SURF算法)

一、SIFT Harris和Shi-Tomasi角点检测算法&#xff0c;这两种算法具有旋转不变性&#xff0c;但不具有尺度不变性&#xff0c;以下图为例&#xff0c;在左侧小图中可以检测到角点&#xff0c;但是图像被放大后&#xff0c;在使用同样的窗口&#xff0c;就检测不到角点了。 尺度…

JavaScript操作CSS样式

上节课我们基本完成了游戏的主体&#xff0c;这节课我们来学习如果使用JavaScript去操作CSS样式 ● 例如&#xff0c;我们现在想当玩家输入对的数字之后&#xff0c;我们讲背景改为绿色&#xff0c;并且把number的框宽度变大 const secretnumber Math.trunc(Math.random() * …

经典算法-----汉诺塔问题

前言 今天我们学习一个老经典的问题-----汉诺塔问题&#xff0c;可能在学习编程之前我们就听说过这个问题&#xff0c;那这里我们如何去通过编程的方式去解决这么一个问题呢&#xff1f;下面接着看。 汉诺塔问题 问题描述 这里是引用汉诺塔问题源自印度一个古老的传说&#x…

目前制造企业生产计划现状是什么?有没有自动化排产系统?

大家都知道&#xff0c;人的指挥中心是大脑&#xff0c;大脑对我们的发出各种各样的指令&#xff0c;告诉我们&#xff1a;“手”做什么事情&#xff0c;“眼睛”看什么地方&#xff0c;“耳朵”听什么声音&#xff0c;然后再将摸到的、看到的、听到的信息传递给大脑&#xff0…

制作 3 档可调灯程序编写

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

maven下载、本地仓库设置与idea内置maven设置

一、下载安装maven maven下载官网&#xff1a;https://maven.apache.org/download.cgi 下载到本地后解压 二、配置环境变量 我的电脑-属性-高级系统设置-环境变量/系统变量 新建MAVEN_HOME 变量值为自己的maven包所在的位置 编辑path 添加 %MAVEN_HOME%\bin 三、测试 Win…

一个案例熟悉使用pytorch

文章目录 1. 完整模型的训练套路1.2 导入必要的包1.3 准备数据集1.3.1 使用公开数据集&#xff1a;1.3.2 获取训练集、测试集长度&#xff1a;1.3.3 利用 DataLoader来加载数据集 1.4 搭建神经网络1.4.1 测试搭建的模型1.4.2 创建用于训练的模型 1.5 定义损失函数和优化器1.6 使…

redis持久化与调优

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

POJ 2886 Who Gets the Most Candies? 树状数组+二分

一、题目大意 我们有N个孩子&#xff0c;每个人带着一张卡片&#xff0c;一起顺时针围成一个圈来玩游戏&#xff0c;第一回合时&#xff0c;第k个孩子被淘汰&#xff0c;然后他说出他卡片上的数字A&#xff0c;如果A是一个正数&#xff0c;那么下一个回合他左边的第A个孩子被淘…

通过usb串口发送接收数据

USB通信使用系统api&#xff0c;USB转串口通信使用第三方库usb-serial-for-android&#xff0c; 串口通信使用Google官方库android-serialport-api。x 引入包后在本地下载的位置&#xff1a;C:\Users\Administrator\.gradle\caches\modules-2\files-2.1 在 Android 中&#x…

【python海洋专题十一】colormap调色

【python海洋专题十一】colormap调色 上期内容 本期内容 图像的函数包调用&#xff01; Part01. 自带颜色条Colormap 调用方法&#xff1a; cmap3plt.get_cmap(ocean)查询方法&#xff01; Part02. seaborn函数包 01&#xff1a;sns.cubehelix_palette cmap5 sns.cu…

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 运算符重载…