首页 > 其他分享 >hdu 4705 Y

hdu 4705 Y

时间:2023-09-12 12:34:37浏览次数:43  
标签:comment 16777216 hdu int LL 4705 MAXN include


dfs

1.要#pragma comment(linker, "/STACK:16777216")

2.扩栈要 vc++编译环境

3.不能用%lld,要用%I64d,无语。。


#pragma comment(linker, "/STACK:16777216")//手动扩栈
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<vector>
using namespace std;

const int MAXN = 1e5+10;
#define LL long long
vector<int> q[MAXN];
int f[MAXN];
LL ans;
int n;

int dfs(int u)
{
	int i,j,temp,sum=0;
	f[u]=1;
	for(i=0;i<q[u].size();i++){
		int v=q[u][i];
		if(!f[v]) {
			temp=dfs(v);
			sum+=temp;
			ans+=(LL)temp*(n-1-temp);
		}
	}
	ans+=(LL)sum*(n-1-sum);
	sum++;
	return sum;
}
int main()
{
	int i,j,k;
	while(scanf("%d",&n)!=EOF){
		int a,b;
		for(i=1;i<=n;i++){
			q[i].clear();
			f[i]=0;
		}
		ans=0;
		for(i=1;i<n;i++)
		{
			scanf("%d%d",&a,&b);
			q[a].push_back(b);
			q[b].push_back(a);
		}
		dfs(1);
		LL t=(LL)n*(n-1)*(n-2)/6;
		printf("%I64d\n",t-ans/2);//用%lld竟然wa。。。
	}
}




标签:comment,16777216,hdu,int,LL,4705,MAXN,include
From: https://blog.51cto.com/u_16244339/7444328

相关文章

  • hdu-3926-Hand in Hand-并查集
    判断两个图是否同构。。用了并查集。。#include<stdio.h>#include<string.h>#include<stdlib.h>#include<algorithm>#include<queue>#include<stack>usingnamespacestd;#definelllonglongintn,m;structnode{ intfu; intsum; intf......
  • HDU 2955 Robberies
    01背包银行总钱数==容量V概率可以算安全的概率p=1-p;#include<stdio.h>#include<string.h>#include<algorithm>usingnamespacestd;doublepp,p[10001],f[10001];intv[10001];intmain(){ intt; scanf("%d",&t); while(t--){ intn,j,i,k,sum......
  • hdu 1372 Knight Moves 骑士的移动 bfs--马走日
    #include<stdio.h>#include<string.h>#include<queue>usingnamespacestd;charss[3],ee[3];intx1,y1,x2,y2;structpos{intx,y,step;}sta,end;intf[10][10];intdir[8][2]={1,2,1,-2,-1,2,-1,-2,2,1,2,-1,-2,1,-2,-1};boolfan......
  • 二叉树 遍历 hdu-1710-Binary Tree Traversals
    给出二叉树的前序遍历和中序遍历,求后序遍历。。 算法:由前序遍历的第一个元素可确定左、右子树的根节点,参照中序遍历又可进一步确定子树的左、右子树元素。如此递归地参照两个遍历序列,最终构造出二叉树。 由前序和中序结果求后序遍历结果树的遍历: 给你一棵树的先......
  • hdu1400/acwing 291 Mondriaan's Dream
    题意描述:给定一块n*m的区域,用1*2的长方形填充,长方形可以横着或竖着摆,问一共有多少种填充方案具体思路:题意没什么好说的,简单易懂,很经典的一类状态压缩问题(在棋盘中求填充方案)。观察数据,满足n,m都比较小,但是搜索的复杂度大到无法接受,考虑使用状态压缩求解此类问题......
  • [HDU4117] GRE
    RecentlyGeorgeispreparingfortheGraduateRecordExaminations(GREforshort).Obviouslythemostimportantthingisrecitingthewords.NowGeorgeisworkingonawordlistcontaining\(N\)words.Hehassopooramemorythatitistoohardforhim......
  • HDU - 7187-Slipper
    HDU-7187-Slipper(最短路、建图优化)题意:给出n个结点,n-1条无向边,经过每条边的代价为w,以结点1为根节点的树,对于相差k层的结点,可以花费代价p抵达,问结点s到t的最短路径。分析:考虑对于每层的每个点建立到相差k层的点的边,极端情况为$O(n^2)$的复杂度,需要优化。考虑对于每层......
  • HDU - 2844 - coins
    HDU-2844-coins(多重背包)题意:大壮想买东西,他有n种不同面值的硬币,每种有$c_i$个,他不想找零,也不想买超过价值m的东西,问他有多少种支付方式。$n(1≤n≤100),m(m≤100000)$分析:可以发现m的范围不大,直接在m中遍历。转化为给定一个容量为m的背包,问装入不同方案时,不同......
  • 代码(待加解释) hdu2196
    #include<bits/stdc++.h>usingnamespacestd;constintmaxn=3e4+10;#definelllonglonginthead[maxn],ver[maxn],nxt[maxn],edge[maxn];inttot;llf[maxn][3];intrx[maxn];voiddfs1(intx,intfa){  for(inti=head[x];i;i=nxt[i])  {   ......
  • hdu:Machine Schedule(二分图匹配)
    ProblemDescriptionAsweallknow,machineschedulingisaveryclassicalproblemincomputerscienceandhasbeenstudiedforaverylonghistory.Schedulingproblemsdifferwidelyinthenatureoftheconstraintsthatmustbesatisfiedandthetypeof......