首页 > 其他分享 >[赛记] 多校A层冲刺NOIP2024模拟赛01【衡中】

[赛记] 多校A层冲刺NOIP2024模拟赛01【衡中】

时间:2024-10-05 12:12:05浏览次数:6  
标签:连边 01 5005 int 衡中 多校 fa include find

构造字符串 50pts

错解50pts;

考虑正解,对于题目中的要求,我们可以转换成若干个相等与不等的操作,若相等则用并查集合并一下,不等则连边,若同块连边则无解,否则从前往后遍历赋值,每次找所连边其它块值的 $ \operatorname{mex} $ 即可;

时间复杂度:$ \Theta(nm \alpha(n)) $;

点击查看代码
#include <iostream>
#include <cstdio>
#include <vector>
#include <cstring>
using namespace std;
int n, m;
int fa[5005];
int find(int x) {
	if (x != fa[x]) fa[x] = find(fa[x]);
	return fa[x];
}
struct sss{
	int x, y, z;
}e[5005];
int cnt;
vector<int> v[5005];
int ans[5005];
bool vis[5005];
int main() {
	freopen("str.in", "r", stdin);
	freopen("str.out", "w", stdout);
	ios::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);
	cin >> n >> m;
	for (int i = 1; i <= n; i++) fa[i] = i;
	int cnt = m;
	memset(ans, -1, sizeof(ans));
	for (int i = 1; i <= m; i++) {
		cin >> e[i].x >> e[i].y >> e[i].z;
		if (e[i].x > e[i].y) swap(e[i].x, e[i].y);
		if (e[i].z != 0) {
			int l = e[i].x;
			int r = e[i].y;
			int o = e[i].z;
			while(o) {
				fa[find(l)] = find(r);
				l++;
				r++;
				o--;
			}
			if (r <= n) {
				e[++cnt] = {l, r, 0};
			}
		} else {
			e[++cnt] = e[i];
		}
	}
	for (int i = m + 1; i <= cnt; i++) {
		int l = e[i].x;
		int r = e[i].y;
		if (find(l) == find(r)) {
			cout << -1;
			return 0;
		}
		v[find(l)].push_back(find(r));
		v[find(r)].push_back(find(l));
	}
	for (int i = 1; i <= n; i++) {
		int x = find(i);
		if (ans[x] != -1) continue;
		for (int j = 0; j <= n; j++) vis[j] = false;
		for (int j = 0; j < v[x].size(); j++) {
			if (ans[v[x][j]] != -1) vis[ans[v[x][j]]] = true;
		}
		for (int j = 0; j <= n; j++) {
			if (!vis[j]) {
				ans[x] = j;
				break;
			}
		}
	}
	for (int i = 1; i <= n; i++) {
		cout << ans[find(i)] << ' ';
	}
	return 0;
}

标签:连边,01,5005,int,衡中,多校,fa,include,find
From: https://www.cnblogs.com/PeppaEvenPig/p/18447745

相关文章

  • [赛记] 冲刺CSP联训模拟1[衡中]
    几何100pts赛时打的$DP$没有用bitset优化过了,也是放过了暴力;考虑设状态$f_{i,j,k}$表示考虑到第$i$位,到第$j$位$x$和第$k$位$y$可不可取,直接转移即可;时间复杂度:$\Theta(|s||x||y|)$,应该是过不了的;点击查看暴力#include<iostream>#incl......
  • Leetcode 1011. 在 D 天内送达包裹的能力
    1.题目基本信息1.1.题目描述传送带上的包裹必须在days天内从一个港口运送到另一个港口。传送带上的第i个包裹的重量为weights[i]。每一天,我们都会按给出重量(weights)的顺序往传送带上装载包裹。我们装载的重量不会超过船的最大运载重量。返回能在days天内将传送带上的所......
  • 2017中国大学生程序设计竞赛 - 女生专场(SDKD 2024 Summer Training Contest K2)
    A-AutomaticJudge题意\(n\)个问题,\(m\)条记录,每条记录有题号、时间、状态,第一次\(AC\)的时候计入罚时,其他没发罚\(20\)分钟。求队伍过题数和罚时。思路模拟。代码点击查看代码#include<bits/stdc++.h>usingnamespacestd;#defineintlonglongvoidsolve()......
  • [Ynoi2012] NOIP2015 充满了希望
    [Ynoi2012]NOIP2015充满了希望题意给一个长为\(n\)的序列,有\(m\)个操作,操作编号从\(1\)到\(m\),每个操作为:1xy:将序列位置为\(x,y\)的两个元素交换。2lrx:将序列区间\([l,r]\)内所有元素修改为\(x\)。3x:查询序列\(x\)位置的值。现在有\(q\)次查询,每次......
  • vs2015安装包丢失或损坏解决工具 或者不能启动
    打开“本地组策略编辑器”(gpedit.msc)。展开“计算机配置”>“管理模板”>“系统”>“Internet通信管理”,然后选择“Internet通信设置”。选择“关闭自动根证书更新”>,“禁用”,然后选择“确定”或“应用”。下载最新的组件版本(备份的)https://learn.microsoft.c......
  • Debuggers 1012:Introductory GDB
    OpenSecurityTraining2LearningPaths:VulnerabilityHunting&Exploitationpython:https://www.learnpython.org/路径图:https://ost2.fyi/OST2_LP_Vulns_Exploits.pdfDebuggers1012:IntroductoryGDB(与python)-->Architecture1001:x86-64Assembly-->R......
  • 【贪心】【二分】[NOIP2015]跳石头
    https://ac.nowcoder.com/acm/contest/22353/C正确的思路是二分查找+贪心。具体来说,可以通过二分来猜测一个最小的跳跃距离,然后通过贪心算法判断是否可以通过移除石头使所有的跳跃都满足这个最小跳跃距离。这种方法的核心是逐步逼近最优解,而不是直接删除前m小的元素。细节:在......
  • 10.2与10.3日noip多校联考总结
    10.2与10.3noip多校联考总结10.2T1考场上推了比较久,想到了对于每个二进制位进行贪心,但是往上面套了二分和判定,导致时间复杂度到了\(O(T\log^3n)\),时间过劣。在考后知道了二分和判定都可以省去。因为要求最小次数,所以不免想到了二分和贪心,用学长讲的“调整法”就可以很好......
  • 多校A层冲刺 NOIP2024 模拟赛 01
    T1构造字符串签到题注意到\(n\)和\(m\)较小,直接扫一遍用并查集维护他所描述的情况,并将不同的位置记录下来,若存在不同的位置属于同一个集合则不可能构成,否则贪心从前往后取mex即可。时间复杂度\(O(nm\alpha(n))\)。T2寻宝签到题首先先用并查集将大联通块缩点,注意到......
  • 2023-11-25 Matlab和Python在气象中的常用代码 180401
    目录画图横坐标添加月份PythonMatlab画图横坐标添加月份Pythonimportmatplotlib.pyplotaspltimportpandasaspdimportnumpyasnp#准备时间和温度数据start_date=pd.to_datetime('1996-12-01')#thenextdateend_date=pd.to_datetime('1998-12-01')#the......