当前位置: 首页 > news >正文

如何起手做网站项目国家市场监督管理总局

如何起手做网站项目,国家市场监督管理总局,百度做网站怎么联系,网络客服怎么做上学 题目描述 usst 小学里有 n 名学生,他们分别居住在 n 个地点,第 i 名学生居住在第 i 个地点,这些地点由 n−1 条双向道路连接,保证任意两个地点之间可以通过若干条双向道路抵达。学校则位于另外的第 0 个地点,第…

上学

题目描述

usst 小学里有 n 名学生,他们分别居住在 n 个地点,第 i 名学生居住在第 i 个地点,这些地点由 n−1 条双向道路连接,保证任意两个地点之间可以通过若干条双向道路抵达。学校则位于另外的第 0 个地点,第 0 个地点与第 1 个地点之间有另外一条双向道路链接。

最近学校开始启用校车来接学生上学,每一辆校车上都可以坐无限个学生,且每辆校车在一天内不会重复经过一条道路,校车终点始终为学校。每一位学生一天内只能乘坐一辆校车,且只能在自己居住的节点处上车,在学校下车。为了节省资金,学校会在保证每位学生都能坐上校车的前提下,安排最少数量的校车,每天早上从某些地点出发,并经过若干道路和地点最终抵达学校。第 x 位学生可以自由选择一辆经过第 x 个地点的校车,搭乘它到达学校。

现在学校想要从 n 个学生中选出 3 人参加某个比赛,但是学校不希望这 3 人之间太过 “熟悉”,请问一共有多少种不同的选人方案。

如果一种选择方案中, 3 个人可能在同一天里乘坐上同一辆校车,那就称这 3 个人之间太过 “熟悉”。

对于任意两个方案,如果存在一名学生在一个方案中且不在另一个方案中,那么就认为这两种方案不同。

输入描述

输入第 1 行包含 1 个正整数 n ,代表学生数量和学生居住的地点数量。( 3 ≤ n ≤ 2 × 1 0 5 3≤n≤2×10^5 3n2×105)

接下来 n−1 行每行有 2 个正整数 u, v ,代表第 u 个地点与第 v 个地点之间有一条双向道路。( 1 ≤ u , v ≤ n 1≤u,v≤n 1u,vn)

输出描述

输出一行,一个整数,代表选人方案数量。

样例输入 #1

5
1 2
2 3
3 4
4 5

样例输出 #1

0

样例输入 #2

5
1 2
2 3
2 4
1 5

样例输出 #2

8

原题

牛客——传送门

思路

根据题目描述可知,学校所选择的校车的路线是每个由叶子节点指向根节点(即节点1)的路径。题目目的是求出从 n 个学生中选择 3 个学生,保证 3 个学生不在同一条由叶子节点指向根节点(即节点1)的路径中的方案数。那么可以采用容斥原理,用不考虑 3 个学生在一条路径上的总的方案数减去 3 个学生在一条路径上的方案数。
求解示例如下:

对于上图所示的树,存在三条从叶子节点到根节点的路径,即 4-1,6-1,7-1,也就是三辆校车行驶的路线。首先,总的方案数为C(n,3)。而 3 个学生在一条路径上的方案数求解如下:C(4,3)+C(5,3)+C(5,3)-C(4,3)-C(3,3)。意思是4-1,6-1,7-1的三条路径中各自分别选取 3 个学生,但是存在重复选取5-1路径和3-1路径的情况。所以我们需要去重,即因为 5 节点下面有两条支链,所以要减去5-1路径的方案数乘以2-1(因为有两条支链,重复求了一次,所以2-1表示多求的数量)即减去C(4,3)。同理,还需要减去3-1路径的方案数即C(3,3)。

代码

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;const int maxn = 2e5 + 6;
vector<int> e[maxn];        // 邻接表存边
vector<pair<int, int>> num; // num.first为路径上的节点个数,num.second为该路径需要计算多少次void dfs(int p, int fa, int depth)
{if (p != 1 && e[p].size() <= 1) // 找到叶子节点{if (depth >= 3){num.push_back({depth, 1});}return;}int child_num = 0;                    // 支链数量,即孩子数量for (int i = 0; i < e[p].size(); i++) // 树的递归遍历{int v = e[p][i];if (v != fa){dfs(v, p, depth + 1);child_num++;}}if (depth >= 3) // 去重{num.push_back({-depth, child_num - 1}); // 加入num数组数指定为-depth,为的是做个标记}
}int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);ll n;cin >> n;for (int i = 1; i < n; i++){int u, v;cin >> u >> v;// 存无向边e[u].push_back(v);e[v].push_back(u);}dfs(1, 0, 1);// 先计算总方案数C(n,3)ll ans = n * (n - 1) * (n - 2) / 6;for (int i = 0; i < num.size(); i++){ll x = num[i].first;if (x > 0) // 若为正数,表示这是叶子节点到根节点的路径中选取学生的方案数ans -= x * (x - 1) * (x - 2) / 6;else // 标记为负数,表示这是要去重的路径中选取学生的方案数{x = -x;ans += x * (x - 1) * (x - 2) / 6 * (ll)num[i].second;}}cout << ans;return 0;
}
http://www.mmbaike.com/news/62695.html

相关文章:

  • 长沙市做网站的网站优化设计电子版在哪找
  • 湖州市住房和城乡建设局网站在线客服
  • 网站追踪如何做网络推广优化培训
  • 网站推广方法100种百家港 seo服务
  • 环评登记表在哪个网站做网络营销的5种营销方式
  • 互联网时代 网站建设西安网站到首页排名
  • 网站建设服务协议 百度网站关键词优化
  • 投诉做单骗子网站seo先上排名后收费
  • 淄博建网站哪家好市场营销策划方案3000字
  • 网络推广工作好吗鄂尔多斯seo
  • 国内专业网站建设公司关键词林俊杰免费听
  • 如何做网站首页优化整站优化网站
  • wordpress 喜欢插件廊坊关键词优化平台
  • 个人网站建设与维护搜索引擎营销经典案例
  • 浙江政务服务网河南郑州网站推广优化外包
  • 挂马网站 名单重庆网站seo好不好
  • 湖北省住房与城乡建设部网站百度贴吧怎么发广告
  • 公司简介怎么写模板搜索引擎优化趋势
  • 可以做描文本的网站app推广公司
  • 12306网站是哪个公司做的百度竞价开户流程
  • 微信上的网站怎么做的品牌宣传策划方案
  • 如何制作新型网站程序seo外链优化策略
  • 彩票做网站发软文
  • 用自己点电脑做电影网站湖南专业关键词优化
  • 内蒙古创意网站开发引擎优化
  • 昆明网站制作内容网页制作公司排名
  • 中央农村工作会议视频云优化seo软件
  • 外围网站做代理关键词搜索点击软件
  • 网站开发模板代码百度知道
  • ace wordpressseo优化的技巧