首页 > 其他分享 >题解【[ABC147F] Sum Difference】

题解【[ABC147F] Sum Difference】

时间:2024-05-03 23:56:26浏览次数:27  
标签:题解 Sum 2D 5D aX Difference sum 3D

题目链接

下为口胡题解:

入手方向推导:
直接考虑题目所给式子显然困难:

\[w(S)=\sum_{i\in S}A_i-\sum_{i\notin S}A_i \]

因为两个式子虽然相关但是都在变化,不妨转化为:

\[w(S)=2\times \sum_{i\in S}A_i-\sum_{i=1}^n A_i \]

这样只用求出有多少个不同的 \(\sum_{i\in S}A_i\)

由于每个 \(A_i\) 加和一定可以表示为 \(aX+bD\) 的形式,不妨将 \(a\) 固定下来进行研究(即选取固定数量的 \(A_i\),那么贡献固定数量的首项 \(X\))。

当 \(a\) 确定,\(\sum_{i\in S}A_i\) 显然可以取到 \([aX+\frac{a(a-1)}{2}D,aX+\frac{a(2n-a-1)}{2}D]\) 之间的每一个数。

比如对于如下的 \(A_i\) 取三个:

X  X+D  X+2D  X+3D  X+4D  X+5D

最小可以取到:\(X+(X+D)+(X+2D)=3X+3D\),最多可以取到 \((X+3D)+(X+4D)+(X+5D)=3X+12D\),其中每一个 \(b\) (\(D\)前的系数)不同的都能取到。

但是还有一种情况,即存在 \(k_1X=k_2D\),那么在某些情况下,即便有两个 \(aX+bD\) 的 \(a,b\) 系数均不相同,也能表示同一个值。

这种情况可以尽可能将刚才计算出的区间中的 \(X\) 尽可能替换为 \(D\)。

最后在相同的 \(X\) 上区间并,并将不同 \(X\) 的答案累加起来即可。

方向总结:尽可能研究变化较少的东西,如果有多个会变,就转化为少量会变进行研究。

标签:题解,Sum,2D,5D,aX,Difference,sum,3D
From: https://www.cnblogs.com/zhangyuzhe/p/18171847

相关文章

  • excel - SUMIF的使用
    SUMIF(range,criteria,[sum_range])range是你要根据条件进行检查的单元格区域。criteria是根据其检查range的条件。这个条件可以是数字、表达式、或文本字符串。[sum_range]是可选的参数,当要求和的数字位于与range不同的区域时使用。如果省略sum_range,Excel会默认......
  • CF1968E.Cells Arrangement-构造(给个和题解不同的做法)
    link:https://codeforces.com/problemset/problem/1968/E题意:需要构造一个\(n\timesn\)的棋盘,在上面放\(n\)枚棋子,设集合\(\mathcal{H}\)表示两两之间曼哈顿距离构成的集合,要让\(|\mathcal{H}|\)最大。给出放棋子的方案。首先说说题解的做法…考虑把距离为奇数和偶数的......
  • 题解:CF1926G
    题目传送门思路发现权值为C的点可以选择看做是权值为S或为P的点,所以问题转换为怎么给C点赋值可以使答案最小,考虑树形dp。\(f_{i,0/i,1}\)表示\(i\)点赋值为S或P时最少要删除几条边。但如果当前点权值不为C的话,那显然他的父亲节点应该选择和他权值相同的点才......
  • 题解:AT_abc298_h [ABC298Ex] Sum of Min of Length
    分析模拟赛签到题。考虑分讨。分两种情况:\(L=R\)。\(L\neR\)。对于第\(1\)种情况,用换根DP求一个\(i\)为根时所有点的深度和就行。对于第\(2\)种情况,钦定$dep_R\gedep_L$。很显然,\(R\)为根的子树中所有点都是离\(R\)更近。假设在\(L\)到\(R\)的路径......
  • 题解【[ABC077D] Small Multiple】
    题目链接题意简述:给定正整数\(K\),求数位之和最小的\(K\)的倍数的数位和。错误方向:\(K\)的倍数一定满足\(K\timesS\),根据\(K\)的特征构造出合适的\(S\)。正确方向考虑直接构造出K的倍数,由于从1开始可以通过×10和+1构造出所有数字,并且在此......
  • 【题解】P4711 「化学」相对分子质量
    Problem给定一个长度为\(L\)的化学式,求出此化学式的相对分子质量。例:十二水合硫酸铝钾(明矾)\(KAl(SO_4)_2\cdot12H_2O\).输入格式形为:KAl(SO_{4})_{2}~12H_{2}OSolve清新小模拟。定义一下“结账”这个概念,分为三种:原子结账,即为当单独的一个(一坨)原子计算完成后,计入所属......
  • [题解]ABC337E Bad Juice
    ABC337EBadJuice一开始的想法如下:就是利用二分法,对于一个区间\([l,r]\),分成\([l,mid-1],[mid,r-1]\)两部分,各找两个朋友喝,右边还空出一个\(r\),如果前面两个朋友都没中毒,那说明\(r\)这瓶有毒。但仔细一想,我们发现\([1,n)\)的瓶子中任意一个我们分出的区间\([l,r]\),都用去了\(......
  • 题解:CF607E Cross Sum
    Problem给定\(N\)条不平行的直线\(y=\frac{k_i}{1000}x+\frac{b_i}{1000}\),\(N\)条直线总共会有\(\frac{N(N-1)}{2}\)个交点(包含在同一个位置的点,即相同位置算不同的点),找出距离原点前\(K\)近的交点的距离和。$2\leN\le5\times10^4$,\(1\leK\le\frac{N(N-1)}{2}\)......
  • P6123 [NEERC2016] Hard Refactoring 题解
    本题说白了,就是一道big模拟!!!题意不再赘述,我们直接看思路。这里作者借鉴了某差分思想:末尾加空格,用于判断最后一个条件;若只有\(\le\),对给出的数字和数组第一个进行标记。标记的时候要+32769,因为数组中不存在负数下标,以免越界;若只有\(\ge\),就标记给出的数字和数组最后......
  • 5.2考试题解
    T1[NOIP2017提高组]时间复杂度大模拟……#include<bits/stdc++.h>#definelllonglongusingnamespacestd;intt,n,k,as,nw,tr,ed[105];intc[26],str[105],b[105];stringtim;stack<int>st;structAadd{strings,t,fr,ed;}ad[105];intdfs(intx){i......