当前位置:网站首页>"Wei cup" school more than 2022 cattle summer camp 4 Nancy (polocy) pelosi article variance law of Arts
"Wei cup" school more than 2022 cattle summer camp 4 Nancy (polocy) pelosi article variance law of Arts
2022-07-30 22:57:00 【HeartFireY】
N.Particle Arts
题目大意
给定序列 a 1 , a 2 , … , a n a_1, a_2, \dots, a_n a1,a2,…,an,每当两个元素 a a a和 b b b相撞后会湮灭并产生两个新元素 a & b a \& b a&b和 a ∣ b a | b a∣b.若干次碰撞后,方差会收敛.求收敛后的方差.
首先可以发现,任意两个元素相撞变化后,不会引起总和的变化,因此均值是不变的.
那么考虑求经过无限此碰撞后生成的新序列,容易发现因为或操作的性质,二进制下为 1 1 1的位不会消失,那么无限次或操作会将为 1 1 1的位向同一数字靠拢.于是直接按位统计后生成新序列计算即可.
如果使用公式 E ( x 2 ) − E 2 ( x ) E(x^2) - E^2(x) E(x2)−E2(x),需要继续推式子;但可以直接怼上方差公式,但是又会爆long long,那么可以在运算过程中全部使用__int128计算,最后转long long输出.
Code
#include <bits/stdc++.h>
#pragma gcc optimize("O2")
#pragma g++ optimize("O2")
#define int __int128
#define endl '\n'
using namespace std;
const int N = 2e5 + 10, MOD = 1e9 + 7;
long long a[N], b[N], cnt[20];
inline void solve(){
long long n = 0, sum = 0; cin >> n;
for(int i = 1; i <= n; i++) cin >> a[i], sum += a[i];
int cnt0 = 0, cnt1 = 0;
for(int i = 1; i <= n; i++){
for(int j = 0; j < 15; j++){
if((a[i] >> j) & 1) cnt[j]++;
}
}
for(int i = 0; i < 15; i++){
for(int j = 1; j <= cnt[i]; j++) b[j] |= (1 << i);
}
int f1 = 0;
for(int i = 1; i <= n; i++){
f1 += (n * b[i] - sum) * (n * b[i] - sum);
}
int f2 = n * n * n;
int gcdd = __gcd(f1, f2);
//cout << f1 << '@' << f2 << endl;
long long ans1 = f1 / gcdd, ans2 = f2 / gcdd;
//cout << (f1 / gcdd) << '/' << (f2 / gcdd) << endl;
cout << ans1 << '/' << ans2 << endl;
}
signed main(){
ios_base::sync_with_stdio(false), cin.tie(0);
cout << fixed << setprecision(12);
int t = 1; //cin >> t;
while(t--) solve();
return 0;
}
边栏推荐
猜你喜欢

Apache Doris系列之:安装与部署详细步骤

二进制序列

抽象类和接口(学习笔记)

#Dasctf July Enabler WP

Navicat connection MySQL error: 1045 - Access denied for user 'root'@'localhost' (using password YES)

Chapter 8 Intermediate Shell Tools II

Go1.18升级功能 - 泛型 从零开始Go语言

$\text{ARC 145}$

Golang go-redis cluster模式下不断创建新连接,效率下降问题解决

Abstract classes and interfaces (study notes)
随机推荐
通过社交媒体建立个人IP的 5 种行之有效的策略
【微信小程序】小程序突破小程序二维码数量限制
Go语学习笔记 - gorm使用 - gorm处理错误 Web框架Gin(十)
ML's shap: Based on FIFA 2018 Statistics (2018 Russia World Cup) team match star classification prediction data set using RF random forest + calculating SHAP value single-sample force map/dependency c
Apache Doris series: In-depth understanding of real-time analytical database Apache Doris
win10重建索引
QT开发简介、命名规范、signal&slot信号槽
可视化工具Netron介绍
【无标题】
Golang 切片删除指定元素的几种方法
【科研】文献下载神器方式汇总
成功解决ImportError: cannot import name ‘_validate_lengths‘
【Untitled】
Summary of BFS questions
ZZULIOJ:1120: 最值交换
$\text{ARC 145}$
抽象类和接口(学习笔记)
【2022-05-31】JS逆向之易企秀
Apache Doris series: detailed steps for installation and deployment
# # yyds dry goods inventory interview will brush TOP101: to determine whether there is a part of the list