IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> [WC2022-DMY]Poborcy podatkowi -> 正文阅读

[人工智能][WC2022-DMY]Poborcy podatkowi

题目

传送门 to usOJ

题目描述
给出一棵树,边有边权。请你找出一些边不交的长度为 4 4 4 的路径,使得权值和最大。输出答案。

数据范围与提示
n ? 2 × 1 0 5 n\leqslant 2\times 10^5 n?2×105,边权 w ∈ [ ? 1 0 9 , 1 0 9 ] w\in[-10^9,10^9] w[?109,109]

思路

显然的 d p \tt dp dp,设 f ( x , j ) f(x,j) f(x,j) 表示 x x x 点处有长度为 j j j 的 “残链”,最大权值和。难点只在于转移。以 f ( x , 0 ) f(x,0) f(x,0) 为例,先 列举我们需要的条件(这有助于分析):

  • 接到这个点上的长度为 1 1 1 的链、为 3 3 3 的链数量相同。
  • 长度为 2 2 2 的链的数量为偶数。

第二个容易记录。第一个相当于 c n t 1 ? c n t 3 = 0 cnt_1-cnt_3=0 cnt1??cnt3?=0 。左式范围是 [ ? n , n ] [-n,n] [?n,n],怎么办?用这道题的想法, shuffle \texttt{shuffle} shuffle 一下。我本以为这是乱搞做法,没想到它有数学依据;是不是数学家就喜欢干这种事情:用我看不懂的公式解释我理解不了的现象,让我大受震撼?

我今天才知道,有一个东西叫 霍夫丁不等式 Hoeffding’s?inequality \text{Hoeffding’s inequality} Hoeffding’s?inequality):对于 n n n 个独立随机变量 x 1 , x 2 , x 3 , … , x n x_1,x_2,x_3,\dots,x_n x1?,x2?,x3?,,xn?,设 P ( x i ∈ [ a i , b I ] ) = 1 \mathbb{P}(x_i\in[a_i,b_I])=1 P(xi?[ai?,bI?])=1,记 S n = ∑ i = 1 n x i S_n=\sum_{i=1}^{n}x_i Sn?=i=1n?xi?,则有
P ( ∣ S n ? E [ S n ] ∣ ? t ) ? 2 exp ? ( ? 2 t 2 n ( b ? a ) 2 ) \mathbb{P}\big(\big|S_n-E[S_n]\big|\geqslant t\big)\leqslant2\exp\left(-2t^2\over n(b-a)^2\right) P(?Sn??E[Sn?]??t)?2exp(n(b?a)2?2t2?)
在本题中就直接套公式吧。由于 1 , 3 1,3 1,3 数量相同, s h u f f l e \tt shuffle shuffle 后近似于各有 1 2 \frac{1}{2} 21? 概率出现,为了方便,就规定为 ? 1 -1 ?1 + 1 +1 +1 。于是 E [ S n ] = 0 E[S_n]=0 E[Sn?]=0,代入 a = ? 1 , ?? b = + 1 a=-1,\;b=+1 a=?1,b=+1
P ( ∣ S n ∣ ? t ) ? 2 exp ? ( ? t 2 2 n ) \mathbb{P}(|S_n|\geqslant t)\leqslant 2\exp\left(\frac{-t^2}{2n}\right) P(Sn??t)?2exp(2n?t2?)
那么,在 t = λ n t=\lambda\sqrt{n} t=λn ? 时,概率的上界已经缩小到 2 exp ? ( ? λ 2 2 ) 2\exp(-{\lambda^2\over 2}) 2exp(?2λ2?),很难的啦!取 λ = 5 \lambda=5 λ=5 之类的,概率已经缩小到 7 × 1 0 ? 6 7\times 10^{-6} 7×10?6,不太可能的啦!

所以复杂度是 O ( n n ) \mathcal O(n\sqrt{n}) O(nn ?) 。但是上面的不等式为啥是正确的,俺也不知道。

代码

#include <cstdio>
#include <iostream>
#include <algorithm>
#include <cstring>
#include <cctype>
#include <random>
using namespace std;
# define rep(i,a,b) for(int i=(a); i<=(b); ++i)
# define drep(i,a,b) for(int i=(a); i>=(b); --i)
typedef long long llong;
inline int readint(){
	int a = 0, c = getchar(), f = 1;
	for(; !isdigit(c); c=getchar())
		if(c == '-') f = -f;
	for(; isdigit(c); c=getchar())
		a = (a<<3)+(a<<1)+(c^48);
	return a*f;
}
inline void getMax(llong &a,const llong &b){
	a ^= ((a-b)>>63)&(b^a); // when a-b < 0, do this
}

const int MAXN = 200005, SQRTN = 450;
const llong INF = (1ll<<60)-1;
llong dp[2][SQRTN<<1|1], tmp[2][SQRTN<<1|1];
int gh[MAXN]; llong f[MAXN][4];
vector< pair<int,int> > G[MAXN];
std::mt19937 rnd;
void solve(int x,int pre){
	if(!G[x].empty() && G[x][0].first == pre)
		G[x].erase(G[x].begin()); // special case
	for(auto it=G[x].begin(); it!=G[x].end(); ++it)
		if(it->first == pre) G[x].erase(it --);
		else solve(it->first,x); // recurse
	const int LEN = gh[G[x].size()];
	shuffle(G[x].begin(),G[x].end(),rnd);
	rep(o,0,1) fill(dp[o],dp[o]+(LEN<<1|1),-INF);
	dp[0][LEN] = 0; // origin of the world
	for(const auto &y : G[x]){
		rep(o,0,1) rep(j,0,LEN<<1){
			tmp[o][j] = dp[o][j]+max(f[y.first][0],f[y.first][3]+y.second);
			if(j) getMax(tmp[o][j],dp[o][j-1]+f[y.first][0]+y.second);
			getMax(tmp[o][j],dp[o^1][j]+f[y.first][1]+y.second);
			getMax(tmp[o][j],dp[o][j+1]+f[y.first][2]+y.second);
		}
		rep(o,0,1) memcpy(dp[o],tmp[o],(LEN<<1|1)<<3);
	}
	f[x][0] = dp[0][LEN], f[x][1] = dp[0][LEN+1];
	f[x][2] = dp[1][LEN], f[x][3] = dp[0][LEN-1];
}

int main(){
	int n = readint();
	for(int i=1,a,b,c,v=1; i!=n; gh[i]=v,++i){
		a = readint(), b = readint(), c = readint();
		G[a].push_back(make_pair(b,c));
		G[b].push_back(make_pair(a,c));
		if((v+1) <= i/(v+1)) ++ v; // one at a time
	}
	rep(i,1,10000) gh[i] = 100;
	gh[0] = 1; solve(1,-1);
	printf("%lld\n",f[1][0]);
	return 0;
}
  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-02-06 13:50:16  更:2022-02-06 13:52:18 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/19 6:21:19-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码