20241003

news/2024/12/22 2:25:03/文章来源:https://www.cnblogs.com/libohan/p/18446473

公交车(bus)

显然的题目,答案就是所有连通块的大小减一之和

#include <bits/stdc++.h>using namespace std;#define int long longconst int N = 1e7 + 5;int n, m, fa[N], sz[N], ans;int find(int x) {if (fa[x] == x) {return x;}return fa[x] = find(fa[x]);
}void merge(int x, int y) {x = find(x), y = find(y);if (x != y) {fa[x] = y;sz[y] += sz[x];}
}signed main() {ios::sync_with_stdio(0);freopen("bus.in", "r", stdin);freopen("bus.out", "w", stdout);cin >> n >> m;for (int i = 1; i <= n; i++) {fa[i] = i;sz[i] = 1;}for (int i = 1, u, v; i <= m; i++) {cin >> u >> v;merge(u, v);}for (int i = 1; i <= n; i++) {ans += max(0ll, (find(i) == i) * (sz[i] - 1));}cout << ans;return 0;
}

出租车(taxi)

我们可以设 \(dp_{i, j}\) 表示从后往前选到第 \(i\) 个数,左端点与右端点的差值 (左右端点就是 \(a, b\) 两个排列分别选到了哪里),最优化属性为最少用了几次单体技(也就是单独移动一次左或右端点),那么如果 \(a_i !\neq b_{i, j}\)(用 \(i - j\) 就可以得到 \(b\) 数组中的对应下标)显然 \(dp_{i, j} = dp_{i + 1, j}\),那么如果 \(a_i = b_{i - j}\), 就是\(dp_{i, j} = min(dp_{i + 1, j - 1}, dp_{i + 1, j + 1}) + 1\) ,显然可以先用滚动数组优化掉第一维,但是第二种转移才是真正有影响的,而第二种转移每次只会有一次,所以我们的时间复杂度就是 \(O(n)\)

#include <bits/stdc++.h>using namespace std;const int N = 1e6 + 5;int n, a[N], b[N], dp[N], pos[N], p[N];int main() {ios::sync_with_stdio(0);cin.tie(0);freopen("taxi.in", "r", stdin);freopen("taxi.out", "w", stdout);cin >> n;for (int i = 1; i <= n; i++) {cin >> a[i];}for (int i = 1; i <= n; i++) {cin >> b[i];pos[b[i]] = i;}for (int i = 1; i <= n; i++) {p[i] = n + i - pos[a[i]];}for (int i = 0; i < n; i++) {dp[i] = 1000000;}for (int i = n; i <= 2 * n; i++) {dp[i] = i - n;}for (int i = n; i >= 1; i--) {dp[p[i]] = min(dp[p[i] + 1], dp[p[i] - 1]) + 1;}cout << n + dp[n] / 2;return 0;
}

出租车(taxi)

我们先最简单的考虑一个小正方形的染色,一个小正方形总共有 \(4\) 个角,染三种颜色,必然会有两个角的颜色相同,如下图:

image

那么 \(a\)\(d\) 的颜色必然不能相同,那么 \(c \neq a 且 c \neq d\) , \(b \neq a 且 b \neq d\),那么 \(c\) 必然等于 \(d\) ,也就是说其实我们知道了这个正方形中的任意两个点就可以推出剩下的两个点.

如图:

image

我们其实只用知道 \(1, 2, 3, 4, 5, 6, 7\) 的颜色即可,那么这就是一个 \(O(2 ^ {n + m})\) 的做法,为啥不是 \(3 ^ {n + m}\)的时间复杂度,因为我们还要保证当前的颜色与前面的不同,所以只有两种选择了,

看下图:

image

接下来找规律即可

#include <bits/stdc++.h>using namespace std;#define int long longconst int N = 5e2 + 5;int t, n, m, fa[N * 4];char ans[N][N], c[N][N];int find(int x) {if (fa[x] == x) {return x;}return fa[x] = find(fa[x]);
}void merge(int x, int y) {x = find(x), y = find(y);if (x != y) {fa[x] = y;}
}void Solve() {cin >> n >> m;for (int i = 1; i <= 2 * (n + m); i++) {fa[i] = i;}for (int i = 1; i <= n; i++) {for (int j = 1; j <= m; j++) {cin >> c[i][j];if (c[i][j] == 'N') {merge(j, m + i);merge(j + (n + m), m + i + (n + m));ans[i][j] = 'N';}else if (c[i][j] == 'Z') {merge(j, m + i + (n + m));merge(j + (n + m), m + i);ans[i][j] = 'Z';}}}for (int i = 1; i <= n; i++) {for (int j = 1; j <= m; j++) {if (c[i][j] != '?') {continue;}if (find(m + i) != find(j + (n + m)) && find(j) != find(m + i + (n + m))) {merge(j, m + i);merge(j + (n + m), m + i + (n + m));ans[i][j] = 'N';}else {merge(j, m + i + (n + m));merge(j + (n + m), m + i);ans[i][j] = 'Z';}}}for (int i = 1; i <= n + m; i++) {if (find(i) == find(i + n + m)) {cout << "0\n";return ;}}for (int i = 1; i <= n; i++) {for (int j = 1; j <= m; j++) {cout << ans[i][j];}cout << "\n";}
}signed main() {ios::sync_with_stdio(0);cin.tie(0);freopen("bike.in", "r", stdin);freopen("bike.out", "w", stdout);cin >> t;while (t--) {Solve();}return 0;
}

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

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

相关文章

C语言中对象式宏

001、不使用对象式宏[root@localhost test]# ls test.c [root@localhost test]# cat test.c ## 测试程序 #include <stdio.h>int main(void) {int i, sum = 0;int v[5] = {3, 8, 2, 4, 6}; ## 定义int【5】 型数组for(i = 0; i < 5; i…

helm学习

引用案例: 学习连接:https://www.bilibili.com/video/BV12D4y1Y7Z7/?p=7&vd_source=e03131cedc959fdee0d1ea092e73fb24 (时间:06:16)helm新建一个chart,然后删除templates里面的文件,重新编写一个,最后完成发布,更新,回滚动作1,创建一个模版的chart包,删除原来的…

R语言中gene symbol 转换为ENTREZID, clusterprofile富集分析

001、genes <- read.table("genes.txt") ## 读取基因symbol head(genes) tail(genes) genes <- genes[genes != "NA_NA" & genes != "unknow",, drop = FALSE] ## 去除无效信息(可选) genes_list <…

折半查找法的平均查找长度(成功/失败)

转载:https://blog.csdn.net/qq_73966979/article/details/131354005

Leetcode 1498. 满足条件的子序列数目

1.题目基本信息 1.1.题目描述 给你一个整数数组 nums 和一个整数 target 。 请你统计并返回 nums 中能满足其最小元素与最大元素的 和 小于或等于 target 的 非空 子序列的数目。 由于答案可能很大,请将结果对 109 + 7 取余后返回。 1.2.题目地址 https://leetcode.cn/problem…

Nuxt.js 应用中的 app:beforeMount 钩子详解

title: Nuxt.js 应用中的 app:beforeMount 钩子详解 date: 2024/10/4 updated: 2024/10/4 author: cmdragon excerpt: app:beforeMount 是一个强大的钩子,允许开发者在用户界面挂载前控制应用的初始化过程。通过有效利用这一钩子,我们可以优化应用的用户体验,保持状态一致…

[leetcode 92] 反转链表 II

题目描述: https://leetcode.cn/problems/reverse-linked-list-ii 给你单链表的头指针 head 和两个整数 left 和 right ,其中 left <= right 。请你反转从位置 left 到位置 right 的链表节点,返回 反转后的链表 。示例 1:输入:head = [1,2,3,4,5], left = 2, right = 4…

Vue3的项目搭建

有两种方式可以搭建: 一:使用vue-cli中的webpack创建 第二:推荐使用vite来创建项目 vite是新一代前端构建工具,新的前端构建工具,比webpack要快一些。 npm create vue@latest 创建完项目后,我们可以看到项目最外层有index.htmlVite项目中,index.html是项目的入口文件,在…

完全私有化部署!一款开源轻量级网站防火墙!

SamWaf —— 是一款适用于小公司、工作室和个人网站的开源轻量级网站防火墙,完全私有化部署,数据加密且仅保存本地,一键启动,支持 Linux,Windows.大家好,我是 Java陈序员。 今天,给大家介绍一款开源轻量级网站防火墙!关注微信公众号:【Java陈序员】,获取开源项目分享…

[题解]SFMOI Round I A~C

Portal:https://www.luogu.com.cn/contest/179008 \(\bf{100+50+50+25+5=\color{indianred}225\color{black}\ ,\ rk.\ 184}\)A - Strange Cake Game 显然对于小W,向下移动蛋糕刀是最有利的;对于小M,向右移动是最有利的。所以双方以最佳状态移动,最终\(x\le y\)的巧克力是…

11-网络物理隔离技术原理与应用

11.1 概述 1)概念 目的:既能满足内外网信息及数据交换需求,又能防止网络安全事件出现 基本原理:避免两台计算机之间直接的信息交换以及物理上的连通,以阻断两台计算机之间的直接在线网络攻击 2)风险网络非法外联 U盘摆渡攻击 网络物理隔离产品安全隐患 针对物理隔离的攻击…

电路的三态机制——以MUX为例

CMOS 电路一般而言是不提供高阻态状态的,要提供高阻状态就得有特殊的电路安排,可是那样就使芯片上的电路单元不规整划一了……对于像这样的电路的实现,现在采用的策略是将其做成标准件供程序员选用,但不向程序员开放高阻状态,以免滥用——《香山源码剖析》5.1 组合电路电路…