首页 > 其他分享 >[CF1588F] Jumping Through the Array

[CF1588F] Jumping Through the Array

时间:2023-11-08 22:44:22浏览次数:56  
标签:std cnt idx ed Jumping maxn Through CF1588F op

不妨认为 \(n,q\) 同阶。

考虑根号重构。如果没有第 3 种操作的话,我们每 \(\mathcal O(\sqrt n)\) 操作整体更新一次,每个询问只需要考虑块内的修改所在置换环上有多少 \([l,r]\) 内的数。这个是容易 \(\mathcal O(n\sqrt n)\) 做的。

然后考虑置换环会变怎么办。注意到一个块内真正会变的 \(p\) 值只有 \(\mathcal O(\sqrt n)\) 个,标记这些会变的位置,剩下的位置会形成若干条链,它们本身不会发生改变之类,所以我们直接把整条链缩到一起。这样一个操作块内就只剩 \(\mathcal O(\sqrt n)\) 个点了。

考虑如何统计答案。我们需要的是一个置换环上 \([l,r]\) 内的点的个数。把询问拆成 \([1,r]\) 减去 \([1,l-1]\),挂到每个缩起来的点上。顺序加入一遍 \(1\sim n\),每次加入把其对应的缩点 +1。其实就是一个扫描线状物。

时间复杂度 \(\mathcal O(n\sqrt n)\)。我实现的不好,需要卡常。我使用了简易火车头。注意到常数大在缩起来的点数还是有点多,其它地方顺序访问常数不大,所以适当取小块长即可。还有交换数组两维使其顺序访问的优化,我还没加上就过了。

#pragma GCC optimize("Ofast")
#pragma GCC optimize("unroll-loops")
#pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,avx2,tune=native")
#include <bits/stdc++.h>
#define pb emplace_back
#define fir first
#define sec second

using i64 = long long;
using pii = std::pair<int, int>;

constexpr int maxn = 2e5 + 5, S = 1000 + 5;
int n, p[maxn], bs, q, idx[maxn], cnt, c[maxn], tr[maxn], tot, ed[maxn], coef[S][S], buc[S];
i64 sum[maxn], ans[maxn], res[maxn], a[maxn];
std::vector<std::tuple<int, int, int>> opt, qry;

void solve() {
	cnt = tot = 0; 
	std::fill(idx + 1, idx + 1 + n, 0);
	std::fill(ed + 1, ed + 1 + n, 0);
	for (auto& [op, x, y] : opt) {
		if (op >= 2 && !idx[x]) idx[x] = ++cnt, ed[cnt] = x;
		if (op == 3 && !idx[y]) idx[y] = ++cnt, ed[cnt] = y;
	}
	std::vector<int> st;
	for (auto& [op, x, y] : opt) {
		if (op >= 2) st.pb(p[x]);
		if (op == 3) st.pb(p[y]);
	}
	for (auto& x : st) {
		if (idx[x]) continue ;
		++cnt; int y = x;
		for (; !idx[y]; y = p[y])
			idx[y] = cnt, ed[cnt] = y;
	}
	qry.clear();
	for (auto& [op, x, y] : opt) {
		if (op == 1) {
			ans[++tot] = sum[y] - sum[x - 1];
			qry.pb(x - 1, -1, tot);
			qry.pb(y, 1, tot);
		}
	}
	std::sort(qry.begin(), qry.end()); int j = 1;
	std::fill(buc + 1, buc + 1 + S, 0);
	std::fill(res + 1, res + 1 + S, 0);
	for (int i = 1; i <= cnt; ++i)
		for (int j = 1; j <= tot; ++j)
			coef[i][j] = 0;
	for (auto& [x, v, id] : qry) {
		while (j <= x) {
			++buc[idx[j]];
			++j;
		}
		for (int i = 1; i <= cnt; ++i)
			coef[i][id] += v * buc[i];
	}
	tot = 0;
	for (auto& [op, x, y] : opt) {
		if (op == 1) {
			++tot;
			for (int i = 1; i <= cnt; ++i)
				ans[tot] += (i64)coef[i][tot] * res[i];
		} else if (op == 2) {
			int z = idx[x], c = 0;
			while (true) {
				c += z == idx[x];
				if (c > 1) break ;
				res[z] += y;
				z = idx[p[ed[z]]];
			}
		} else {
			std::swap(p[x], p[y]);
		}
	}
	for (int i = 1; i <= tot; ++i)
		printf("%lld\n", ans[i]);
	for (int i = 1; i <= n; ++i)
		a[i] += res[idx[i]], sum[i] = sum[i - 1] + a[i];
	return ;
}

int main() {
	scanf("%d", &n);
	for (int i = 1; i <= n; ++i)
		scanf("%lld", &a[i]), sum[i] = sum[i - 1] + a[i];
	for (int i = 1; i <= n; ++i)
		scanf("%d", &p[i]);
	scanf("%d", &q); bs = sqrt(q); bs = std::max(bs / 2, 1);
	for (int i = 1; i <= q; ++i) {
		int op, l, r; scanf("%d %d %d", &op, &l, &r);
		opt.pb(op, l, r);
		if (i % bs == 0 || i == q) solve(), opt.clear();
	}
	return 0;
}

标签:std,cnt,idx,ed,Jumping,maxn,Through,CF1588F,op
From: https://www.cnblogs.com/663B/p/17818535.html

相关文章

  • A Tour Through TREE_RCU's Expedited Grace Periods (翻译)
    原文:https://www.kernel.org/doc/html/latest/RCU/Design/Expedited-Grace-Periods/Expedited-Grace-Periods.htmlATourThroughTREE_RCU'sExpeditedGracePeriods通过TREE_RCU的加速宽限期进行一次旅行Introduction引言ThisdocumentdescribesRCU'sexpeditedgracep......
  • A Tour Through TREE_RCU's Grace-Period Memory Ordering (翻译)
    原文:https://docs.kernel.org/RCU/Design/Memory-Ordering/Tree-RCU-Memory-Ordering.htmlAugust8,2017ThisarticlewascontributedbyPaulE.McKenneyIntroductionThisdocumentgivesaroughvisualoverviewofhowTreeRCU'sgrace-periodmemoryorderi......
  • A Tour Through TREE_RCU's Data Structures (翻译)
    原文:https://www.kernel.org/doc/html/latest/RCU/Design/Data-Structures/Data-Structures.htmlDecember18,2016ThisarticlewascontributedbyPaulE.McKenneyIntroductionThisdocumentdescribesRCU'smajordatastructuresandtheirrelationshiptoea......
  • Lora升级!ReLoRa!最新论文 High-Rank Training Through Low-Rank Updates
    关注公众号TechLead,分享AI与云服务技术的全维度知识。作者拥有10+年互联网服务架构、AI产品研发经验、团队管理经验,同济本复旦硕,复旦机器人智能实验室成员,阿里云认证的资深架构师,项目管理专业人士,上亿营收AI产品研发负责人。摘要尽管通过扩展导致具有数千亿参数的大型网络在统......
  • Lora升级!ReLoRa!最新论文 High-Rank Training Through Low-Rank Updates
    关注公众号TechLead,分享AI与云服务技术的全维度知识。作者拥有10+年互联网服务架构、AI产品研发经验、团队管理经验,同济本复旦硕,复旦机器人智能实验室成员,阿里云认证的资深架构师,项目管理专业人士,上亿营收AI产品研发负责人。摘要尽管通过扩展导致具有数千亿参数的大型网络在......
  • Can't connect to local MySQL server through socket '/tmp/mysql.sock'
    Can'tconnecttolocalMySQLserverthroughsocket'/tmp/mysql.sock' 删除配置文件后重启servicemysql restart  root316191014:06?00:00:00/bin/sh/home/mysql/bin/mysqld_safe--datadir=/home/mysql/data--pid-file=/home/mysql/data/localhos......
  • QCN9074-6E Throughput Test Report in DR6018
    IPQ6010+QCN9074|QCN9074-6EThroughputTestReportinDR6018AreyoucuriousabouttheperformancecapabilitiesoftheQCN9074-6EnetworkcardintheDR6018?Looknofurther!Inthisblog,we'llwalkyouthroughthehardwareyou'llneed,howtose......
  • Internet-augmented language models through few-shot prompting for open-domain qu
    Internet-augmentedlanguagemodelsthroughfew-shotpromptingforopen-domainquestionanswering 其实我没怎么正经读过论文,尤其是带实验的,我目前认真读过的(大部头)也就是一些LLM的综述。记录这个文档主要是防止自己读着读着玩手机去了/注意力不集中了跑路了/没记录困惑导......
  • Go - Serving Through HTTPS
    Problem: YouwanttoserveyourwebapplicationthroughHTTPS.Solution: Usethehttp.ListenAndServeTLSfunctiontoserveyourwebapplicationthroughHTTPS. HTTPSisnothingmorethanlayeringHTTPontopoftheTransportSecurityLayer(TLS).Thenet......
  • Triangle Graph Interest Network for Click-through Rate Prediction
    目录概TGINMotivation:Triangle的重要性Model代码JiangW.,JiaoY.,WangQ.,LiangC.,GuoL.,ZhangY.,SunZ.,XiongY.andZhuY.Trianglegraphinterestnetworkforclick-throughrateprediction.WSDM,2022.概'图'用于精排,但是这里的图的使用主要是基于......