首页 > 其他分享 >CF1270G Subset with Zero Sum

CF1270G Subset with Zero Sum

时间:2024-01-05 20:22:22浏览次数:40  
标签:Subset le limits int sum Sum Zero CF1270G loop

G. Subset with Zero Sum

很妙。
一开始冲着背包去想的,显然不行。
考虑他条件给的这个 \(i − n \le a_i \le i − 1\)
化简一下得到

\[1 \le i - a_i \le n \]

题目要去求

\[\sum \limits_{i \in S} a_i = 0 \]

把所给信息往这个式子上靠。
得到

\[\sum \limits_{i \in S} i = \sum \limits_{i \in S} i - a_i \]

考虑以下性质。
如果一个图中存在一个环,那么显然有

\[\sum \limits_{i \in loop} i = \sum \limits_{i \in loop} to_i \]

其中 \(to_i\) 为 \(i\) 指向的点。
回到题目,不妨建这么一张图,\(i\) 向 \(i - a_i\) 连边。
那么如果有环

\[\sum \limits_{i \in loop} i = \sum \limits_{i \in loop} i - a_i \]

\[\sum \limits_{i \in loop} a_i = 0 \]

因此,建图,找环。

void solve() {
	int n;
	cin >> n;
	vector<int> to(n + 1);
	for(int i = 1, x; i <= n; ++ i) {
		cin >> x;
		to[i] = i - x;
	}
	vector<bool> vis(n + 1, 0);
	int x = 1;
	while(!vis[x]) vis[x] = true, x = to[x];
	vector<int> ans;
	do {
		ans.push_back(x);
		x = to[x];
	} while(x != ans[0]);
	cout << ans.size() << '\n';
	for(int y : ans) cout << y << ' ';
	cout << '\n';
}

标签:Subset,le,limits,int,sum,Sum,Zero,CF1270G,loop
From: https://www.cnblogs.com/Luxinze/p/17948011

相关文章

  • 短小精悍(5) - Rust内存清零库zeroize介绍
    今天带来的是一个“短小精悍”的库:zeroize。zeroize可以在确保不被编译器优化的前提下安全高效地清空一段内存,适合在保密应用内使用。用法zeroize的核心用法很简单:usestd::string::String;usezeroize::Zeroize;fnmain(){letmutuser_password=String::from("qw......
  • GPT Zero 是什么?
    fromhttps://openaigptguide.com/gptzero/在人工智能技术飞速发展的今天,人们对于文字内容的准确性和可信度要求越来越高。例如在学术研究领域,防止抄袭和造假是非常重要的。而对于普通用户而言,辨别哪些内容是由人工智能生成的,哪些内容是由人类编写的,也逐渐成为一个亟待解决的问题......
  • c zero length array 零长度数组
    structuserdata{uint32_tlen;uint8_tdata[0];};在阅读一些开源代码时,比如linuxkernel,会发现上面这种用法,这种叫做零长度数组。有什么作用呢?简单来说为了开发便利,顺便节省空间。使用限制只能放在结构体结尾,也就是一个结构体只能有一个零长度数组。使用场景比......
  • CF660E Different Subsets For All Tuples
    题意给定一个长度为\(n\)的序列。每个数字的范围为\([1,m]\)。求一共\(m^n\)种数列,每个数列种本质不同的子序列个数之和。Sol考虑用一种比较好的方式表示答案。枚举本质不同的子序列长度,枚举中间跳过的数的个数。\[m^n+\sum_{i=1}^n\sum_{j=0}^{n-i......
  • Hzero教程:初始化数据库及同步表结构(基于liquibase + groovy)
    初始化数据库更新时间:2023-12-0115:38:30介绍项目创建成功之后,需要初始化本地数据库。在开发之前,请确保本地项目已经创建成功,详见创建项目创建用户确保数据库启动成功,并创建项目访问的用户。CREATEUSER'hzero'@'%'IDENTIFIEDBY"hzero";创建数据库用户创建成功之后,创建项目对......
  • Hzero教程:创建基于hzero的springboot单体maven项目完整步骤
    创建项目更新时间:2023-12-0115:38:30介绍项目是基于Springboot的maven项目,本章节介绍怎样创建基于HZERO平台的项目。新建maven项目添加项目依赖添加默认配置文件创建maven项目本地新建一个空的maven项目hzero-todo-service。$mkdir-phzero-todo-service$cdhzero-tod......
  • 人工智能大模型原理与应用实战:从OpenAI Five到MuZero
    1.背景介绍人工智能(AI)是计算机科学的一个分支,研究如何使计算机能够像人类一样进行智能操作。AI的目标是让计算机能够理解自然语言、进行逻辑推理、学习自主决策、进行视觉识别、进行语音识别等等。AI的主要技术有机器学习、深度学习、神经网络、自然语言处理、计算机视觉、机器人等......
  • linux内核中的zero-page
    zero-page操作系统给用户新分配的内容(通过mmap或者brk)都是清零过的,但是这些虚拟地址通常都是按需分配物理页面。这里的“按需”的需求可能是读取,也可能是写入。如果只是读取,只要保证读取内容是零即可,在MMU的基础上,可以让“所有”虚拟地址都映射到内容为0的物理页面中。这样如......
  • subprocess.CalledProcessError: Command ‘[‘ninja‘, ‘-v‘]‘ returned non-zero
    一、原因pytorch版本大于1.5二、解决1、降低pytorch版本将pytorch版本降到1.5以下2、禁用ninjiapytorch默认使用ninjia作为backend,将其禁用。替换为以下代码setup(...,cmdclass={#'build_ext':BuildExtension,'build_ext':BuildExtensi......
  • 【CF1661B】Getting Zero(广度优先搜索)
    题目大意:每次操作可以把\(v\)变成\((v+1)\mod32768\)或\((2\timesv)\mod32768\),求\(v\)变成\(0\)最少需要操作几次。\(v\)等于\(0\)时答案为\(0\),我们将\(0\)标记,然后让\(0\)入队。然后不断进行以下操作,直到队列为空:1.取出队列头部元素,设为\(x\)。2.找出能通过一次操作变......