首页 > 其他分享 >P4681 [THUSC2015]平方运算 题解

P4681 [THUSC2015]平方运算 题解

时间:2023-04-28 18:45:43浏览次数:56  
标签:题解 复杂度 元素 pushdown THUSC2015 循环 P4681 区间

题面链接

简要题意

给定一个序列,区间 .map([](int x) { x = x * x % p; });,区间求和。
p 给定,为小质数。\(N,M\le 10^5\)。

题解

而把一个数看作一个点,向其平方取模连一条边,则最终必然构成一个基环森林,注意到 \(P\) 很小,每个数经过 \(11\) 次迭代之后就会进入环中。对于一个区间,如果区间中的每个元素都已经在环里,则区间所有元素所在环的大小的 \(\operatorname{lcm}\),即为区间的循环节。而对于题目给出的 \(P\),\(\operatorname{lcm}\le 60\),记为 \(C\)。
先考虑初始是每个元素都在环内的时候怎么做:发现可以用线段树维护,对于每个区间,我们可以直接维护该区间的一个完整循环节,以及当前在循环节内的位置 now,则如果要对整个区间进行 \(k\) 次修改,则直接让 now 向前移动 \(k\) 即可,故可以 \(O(1)\) pushdown,如果一个区间的子区间被修改了,那么在 pushup 的时候直接根据两个子区间的循环节算出当前区间的循环节即可,复杂度 \(O(C)\)。

如果一个区间内包含不在环内的元素,则无法维护循环节,我们只维护当前区间的和,需要 pushdown 时暴力递归向子区间 pushdown。由于每个元素经过至多 \(S=11\) 次操作后进入环,简单均摊分析发现这一部分增添的复杂度是 \(O(nS\log n)\) 的。

总时间复杂度 \(O(n\log n(C+S))\) 可以通过。

对于循环移位维护一个循环节和当前位置的指针是十分显然的。

标签:题解,复杂度,元素,pushdown,THUSC2015,循环,P4681,区间
From: https://www.cnblogs.com/watware-cym/p/17362944.html

相关文章

  • “makefile:425: *** 遗漏分隔符 。 停止。”问题解决
    在终端下输入make时出现“makefile:2:***遗漏分隔符。停止。”问题,原因是在编写makefile文件时:3:3.c        gcc-o33.cgcc前的是tab分隔符,不能用空格,否则会出现“makefile:2:***遗漏分隔符。停止。”提示。。。make中规定每一Shell命令之前的开头必须使用<t......
  • 题解(开始学知识点
    D.FrogTraveler1900dpgq!https://codeforces.com/contest/1602/problem/D题解:我们可以通过类似bfs的过程找到每个点的能到达的所需步数最小的点,完成更新,但每个点能被哪些点到达很难判断,故我们反过来考虑,如果我们能得到从n->0的最短跳跃次数,亦得解,而每个点下一步能到达的点容......
  • P1345 [USACO5.4]奶牛的电信Telecowmunication 题解
    一、题目描述:n个点,m条边,给定起点s和终点t,求最少删去几个点后,s和t不连通。注意,s和t不能删掉。1<=n<=100,1<=m<=600; 二、解题思路:刚刚学了最大费用流,知道最大流等于最小割。但此题割的不是边,是点。我们需要将将割点转化为割边。把一个点切成两半......
  • 【题解】P3185 [HNOI2007]分裂游戏
    P3185[HNOI2007]分裂游戏题目描述聪聪和睿睿最近迷上了一款叫做分裂的游戏。该游戏的规则是:共有\(n\)个瓶子,标号为\(0,1,\ldots,n-1\),第\(i\)个瓶子中装有\(p_i\)颗巧克力豆,两个人轮流取豆子,每一轮每人选择\(3\)个瓶子,标号为\(i,j,k\),并要保证\(i\ltj,j......
  • 【题解】P4363 [九省联考 2018] 一双木棋 chess
    原题链接题目描述菲菲和牛牛在一块\(n\)行\(m\)列的棋盘上下棋,菲菲执黑棋先手,牛牛执白棋后手。棋局开始时,棋盘上没有任何棋子,两人轮流在格子上落子,直到填满棋盘时结束。落子的规则是:一个格子可以落子当且仅当这个格子内没有棋子且这个格子的左侧及上方的所有格子内都有棋......
  • BUAACTF2023 Writeup题解 by Joooook
    BUAACTF2023WriteupbyJoooook目录MiscWhichElementchatgptzhuzhuzhuzhu'srevengeScreenshotcarzymazeMCCryptoBlockCipherMathKeyExchangeWebmotaReverseoneQuiz'srevenge*SnakeMinesweepobfu可以从队名猜一下博主是哪里人(nooffline......
  • 【题解】XX Open Cup, GP of Moscow
    //createdon23.03.26目录A.AliceandBobB.BracketsC.CirclesD.DejaVuE.EasiestSumF.FunnySalesmanG.GraphColoringH.HiddenGraphI.InsectsJ.JoiningPointsA.AliceandBob对于链上的情况,异色点是一定不会选择走进同色段的(长度不小于\(2\)),因为一定不优。......
  • springboot入门时,发现Java版本与Spring boot版本无法对应导致错误的问题解决
    <?xmlversion="1.0"encoding="UTF-8"?><projectxmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/......
  • Hackpack 2023 逆向Re部分题解
    Hackpack2023-2023/4/15https://ctf2023.hackpack.club/challenges做了2题出来,其实是一题,第一题是手动逆向,第二题是脚本自动逆向主要是学习到了nclib包使用使用说明https://nclib.readthedocs.io/en/latest/netcat.htmlSpeed-Rev题目是在3分钟逆向6题第一题是直接找字符......
  • leetcode-350-两个数组的交集 II 题解
    题目给定两个数组,编写一个函数来计算它们的交集。示例1:输入:nums1=[1,2,2,1],nums2=[2,2]输出:[2,2]示例2:输入:nums1=[4,9,5],nums2=[9,4,9,8,4]输出:[4,9]说明:输出结果中每个元素出现的次数,应与元素在两个数组中出现次数的最小值一致。我们可以不考虑输出结果......