当前位置:网站首页>“蔚来杯“2022牛客暑期多校训练营4 N.Particle Arts 规律 方差
“蔚来杯“2022牛客暑期多校训练营4 N.Particle Arts 规律 方差
2022-07-30 22:47: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;
}
边栏推荐
- IJCAI2022教程 | 口语语言理解:最新进展和新领域
- VS2017 compile Tars test project
- The problem of sticky packets in tcp protocol transmission
- mysql获取当前时间
- ML之shap:基于FIFA 2018 Statistics(2018年俄罗斯世界杯足球赛)球队比赛之星分类预测数据集利用RF随机森林+计算SHAP值单样本力图/依赖关系贡献图可视化实现可解释性之攻略
- MySQL cursors
- ThinkPHP高仿蓝奏云网盘系统源码/对接易支付系统程序
- QT开发简介、命名规范、signal&slot信号槽
- Gxlcms有声小说系统/小说听书系统源码
- 使用LVS和Keepalived搭建高可用负载均衡服务器集群
猜你喜欢

Advanced c language: pointers (5)

IDEA usage skills

【MySQL】DQL相关操作

MySQL compressed package installation, fool teaching

MYSQL JDBC图书管理系统

@RequestBody、 @RequestParam 、 @PathVariable 和 @Vaild 注解

【无标题】

【云驻共创】HCSD大咖直播–就业指南

Solve npm warn config global `--global`, `--local` are deprecated. use `--location=global` instead

482-静态库、动态库的制作、使用及区别
随机推荐
反转链表-头插反转法
2sk2225 Substitute 3A/1500V Chinese Documentation【PDF Data Book】
Go1.18升级功能 - 泛型 从零开始Go语言
【Untitled】
Golang 切片删除指定元素的几种方法
Go语学习笔记 - gorm使用 - 事务操作 Web框架Gin(十一)
IDEA 连接 数据库
MySql统计函数COUNT详解
MySQL连接时出现2003错误
关于XML的学习(一)
DFS题单以及模板汇总
QT开发简介、命名规范、signal&slot信号槽
PhpMetrics usage
win10重建索引
设备树的引入与体验
TCP 连接 三次握手 四次挥手
cookie和session区别
2sk2225代换3A/1500V中文资料【PDF数据手册】
IJCAI2022 Tutorial | Spoken Language Comprehension: Recent Advances and New Fields
语言代码表