首页 > 其他分享 >【题解】NOIP2021 - 方差

【题解】NOIP2021 - 方差

时间:2023-11-05 21:46:29浏览次数:45  
标签:方差 int 题解 sum 差分 数组 NOIP2021 id

NOIP2021 - 方差

https://www.luogu.com.cn/problem/P7962

想当年我第一次站在 noip 赛场上,过了 T1 剩下三题就一题不会了……幸好这题拿了点分水了个一等。


观察操作:若对于连续的三个数 \(a,b,c\),对 \(b\) 进行一次操作后就变成了 \(a,a+c-b,c\)。求出两个数组的差分数组:\(b-a,c-b\) 与 \(c-b,b-a\)。可以发现一次操作相当于差分数组中的邻项交换。

然后又因为将 \(a\) 数组全体加减一个数方差 \(D\) 是不变的……所以我们可以求出长度为 \(n-1\) 的差分数组 \(d\),然后考虑 \(d\) 数组。

我们对方差进行一个推式子,最后得到了

\[n^2D=\sum_{i=1}^{n-1}id_i*(n-i)d_i+2\sum_{i=1}^{n-1}\sum_{j=i+1}^{n-1}id_i*(n-j)d_j \]

感性理解,要使这个最小,那就要将大的 \(d\) 与偏远部分的下标对应,故最优解的差分数组应该是单谷的。

考虑先对 \(d\) 数组从小到大排序,然后 dp。这个式子不好去 dp,回归本源:

\[n^2D=n\sum a_i^2-(\sum a_i)^2 \]

设 \(f_i\) 表示考虑到前 \(i\) 个 \(d\) 时后面那串的最小值?发现状态中信息不太够。把当前 \(x=\sum a_i\) 放到状态里就可以了。\(f_{i,x}\) 表示前 \(i\) 个 \(d\),构成的 \(a\) 数组和为 \(x\) 时最小的 \(\sum a^2\)。

易得转移。\(d_i\) 放在右边(\(s=\sum_{j=1}^i d_j\)):

\[f_{i-1,x} + s^2 \to f_{i,x+s} \]

放在左边:

\[f_{i-1,x} + 2xd_i + id_i^2 \to f_{i,x+id_i} \]

复杂度 \(O(n^2a)\),观察到当 \(n>a\) 时差分数组会有大量 \(0\),而这些 \(0\) 一定出现在排序后的 \(d\) 数组开头,那么这个时候 \(s\) 也为 \(0\),不管是放在哪边都不会产生转移。所以跳过就行。注意这里跳过只是跳过 \(d_i\),而 \(i\) 还是要加的。那么现在复杂度就是 \(O(na^2)\),注意实现,数组要滚动,不要用 memset

//P7962
#include <bits/stdc++.h>
using namespace std;

const int N = 1e4 + 10, M = 610;
int n, a[N], m, mx;
typedef long long ll;
ll f[2][N*M], d[N], s[N];

int main(){
	scanf("%d", &n);
	for(int i = 1; i <= n; ++ i){
		scanf("%d", &a[i]);
	}
	for(int i = 2; i <= n; ++ i){
		d[i-1] = a[i] - a[i-1];
	}
	sort(d + 1, d + n);
	for(int i = 1; i < n; ++ i){
		s[i] = s[i-1] + d[i];
	}
	memset(f, 0x3f, sizeof(f));
	f[0][0] = 0;
	int p = 0;
	for(int i = 1; i < n; ++ i){
		if(!d[i]){
			continue;
		}
		p ^= 1;
		for(int j = 0; j <= mx; ++ j){
			if(f[p^1][j] == 0x3f3f3f3f3f3f3f3f){
				continue;
			}
			f[p][j+s[i]] = min(f[p][j+s[i]], f[p^1][j] + s[i] * s[i]);
			f[p][j+i*d[i]] = min(f[p][j+i*d[i]], f[p^1][j] + i * d[i] * d[i] + 2 * j * d[i]);
			mx = max(mx, j + (int)max(s[i], i * d[i]));
			f[p^1][j] = 0x3f3f3f3f3f3f3f3f;
		}
	}
	ll ans = 9e18;
	for(int j = 0; j <= mx; ++ j){
		if(f[p][j] < 0x3f3f3f3f3f3f3f3f){
			ans = min(ans, f[p][j] * n - (ll)j * j);
		}
	}
	printf("%lld\n", ans);
	return 0;
}

标签:方差,int,题解,sum,差分,数组,NOIP2021,id
From: https://www.cnblogs.com/KiharaTouma/p/NOIP2021T3.html

相关文章

  • 2023联合省选 题解
    目录D1T1P9166[省选联考2023]火车站D1T2P9167[省选联考2023]城市建造D1T3P9168[省选联考2023]人员调度D2T1P9169[省选联考2023]过河卒D2T2P9170[省选联考2023]填数游戏D2T3P9171[省选联考2023]染色数组D1T1P9166[省选联考2023]火车站性质很好找。关......
  • 题解 P6878 [JOI 2020 Final] JJOOII 2
    好久没写题解,水一篇。题意题意显然。分析看到这道题,我们就应该进行一个小贪心,对于最左边某一字符,直到最右边的这一字符,我们不会在中间删除同样的字符,不然则可以保留这一字符,将两边往内缩。也就是说,我们确定了最左边的J后,那么留下最后一个J必然是当前这个J的后面的第\(......
  • ARC_068F Solitaire题解
    非常骚的一道题首先看数据范围就很像dp(而且在dp专题里),尝试直接dp,发现不太行手玩一波样例,发现答案是2的若干次方乘一个系数。我们发现“若干”=n-k-1,这是巧合吗!?思索一番,会发现当我们取完k个数后剩下的n-k个数取法就为2^(n-k-1),为什么呢?可以把每次操作看成“前取“”or......
  • 2023年11月第一周题解-------数组
    1.问题A:LY学长的随机数解题思路第一种思路是先去重后排序第二种思路是先排序再去重解题方法暴力遍历#define_CRT_SECURE_NO_WARNINGS#include<stdio.h>#include<stdlib.h>#include<string.h>#include<math.h>#include<time.h>#defineN10voidquickSort......
  • CF1838C题解
    显然\(1\)不是质数,除二外偶数不是质数。然后分类讨论对于\(m\)为偶数,构造\[\begin{bmatrix}1&2&3&\cdots&m\\m+1&m+2&m+3&\cdots&2m\\&&\cdot\\&&\cdot\\&&\cdot\\......
  • CF859G 题解
    总结题意显然可以转化为序列问题嘛。给出序列\(A\{a_i\}\),你需要通过若干次操作使其归零。操作:选定\(d|n\)、\(k\)、\(r\),对于序列中所有满足\(i\bmodd=r\)的位置加上\(k\)。题解很明显,加减相互抵消,对于所有\(d\)、\(r\)相同的位置可以视作一次操作。如何表示......
  • CF773A 题解
    真的是蓝题?这真的不是小学数学题?我们是要求满足(其中\(a\)为正确数,\(b\)为总数)\[\frac{x+a}{y+b}=\frac{p}{q}\]的最小\(b\)。我们可以先把右式的分子分母变化到与\(\frac{x}{y}\)类似的大小。intbs1=x/p+(x%p!=0);intbs2=y/q+(y%q!=0);i......
  • 【洛谷 P1909】[NOIP2016 普及组] 买铅笔 题解(打擂台法)
    [NOIP2016普及组]买铅笔题目背景NOIP2016普及组T1题目描述P老师需要去商店买支铅笔作为小朋友们参加NOIP的礼物。她发现商店一共有种包装的铅笔,不同包装内的铅笔数量有可能不同,价格也有可能不同。为了公平起见,P老师决定只买同一种包装的铅笔。商店不允许将铅笔的包装......
  • USACO铂金题解
    USACO铂金题解USACO2018PlatiumB.SortItOut很巧妙的转换注意到操作并不会影响没有被选中的牛的相对顺序所以没有被选中的一定单调递增要使得选中的尽可能少,就要选尽可能长的没有被选中的序列,即原序列的\(LIS\)所以原题等价于求原序列第\(k\)大\(LIS\)用树状数组......
  • [ARC140B] Shorten ARC 题解
    分析自然,我们可以想到利用贪心去解题。我们可以证明,$\texttt{ARC}$左右两边$\texttt{A}$和$\texttt{C}$个数多的比少的变为$\texttt{R}$贡献能更多,第奇数次操作比第偶数次能使操作次数更多。于是,我们可以得出这样的一个算法:若为奇数次操作那我们将现有的$\texttt{ARC......