此题坑点:

  • 结果必须要用long long存,int存不下

  • 如果想要像cout<<sum*pow(2,num-1)这样在输出时计算会错:
    long long在计算过程被隐式转换成了double,需要用强制类型转换转换回long long输出。

  • 集合论和排列组合公式初中还没学


题目描述

给定一个集合s(集合元素数量<=30),求出此集合所有子集元素之和。

分析

我们来看一个例子: \{1,2,3\}{1,2,3}

可以得到,它的所有非空子集为 \{1,2,3\}{1,2,3} \{1,2\}{1,2}\{2,3\}{2,3} \{1,3\}{1,3} \{1\}{1} \{2\}{2} \{3\}{3}

现在来分析每一个元素在每一个子集中出现的个数:

11出现了44次,22出现了44次,33出现了44次

我们猜测:对于一个有限集合AA,它的每一个元素在AA的所有子集中出现的个数是{2^{\operatorname{card}(A)-1}}2card(A)−1

证明:(集合论纯自学,可能格式有误, 请别在意QAQ)

设B\subseteq AB⊆A, 记n=\operatorname{card}(A)n=card(A), ss为AA中所有元素之和

当\operatorname{card}(B)=1card(B)=1时,显然,每个元素在BB中出现11次;

当\operatorname{card}(B)=2card(B)=2时,保证一个元素必选,在剩余的n-1n−1个元素中选择11个元素,共C^1_{n-1}=n-1Cn−11​=n−1种情况,故每个元素在BB中出现C^1_{n-1}=n-1Cn−11​=n−1次;

当\operatorname{card}(B)=3card(B)=3时,保证一个元素必选,在剩余的n-1n−1个元素中选择22个元素,共C^2_{n-1}=\frac{(n-1)!}{2(n-1-2)!}=\frac{(n-1)(n-2)}{2}Cn−12​=2(n−1−2)!(n−1)!​=2(n−1)(n−2)​种情况,故每个元素在BB中出现共C^2_{n-1}=\frac{(n-1)(n-2)}{2}Cn−12​=2(n−1)(n−2)​次;

当\operatorname{card}(B)=kcard(B)=k时,保证一个元素必选,在剩余的n-1n−1个元素中选择k-1k−1个元素,共C^{k-1}_{n-1}Cn−1k−1​种情况,故每个元素在BB中出现共C^{k-1}_{n-1}Cn−1k−1​次;

那么,每个元素在AA的每一个子集中出现的个数为: \sum\limits_{i=1}^{n}C^{i-1}_{n-1}=2^{n-1}i=1∑n​Cn−1i−1​=2n−1 ①

AA的所有子集元素之和为s\times2^{n-1}s×2n−1

故代码如下:

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. int main(){
  4. long long tmp,num=,sum=;
  5. while(cin>>tmp){
  6. sum+=tmp;
  7. num++;
  8. }//读入集合元素个数num和元素和sum
  9. cout<<(long long)(sum*pow(,num-));
  10. //必须显式地转换为long long输出
  11. }

①: 不懂为什么\sum\limits_{i=1}^{n}C^{i-1}_{n-1}=2^{n-1}i=1∑n​Cn−1i−1​=2n−1的可以看一下数学归纳法证明:

将用到的性质公式:

  • C^m_n=C^{m-1}_{n-1}+C^{m}_{n-1}Cnm​=Cn−1m−1​+Cn−1m​
  • C^n_n=C^0_n=1Cnn​=Cn0​=1

\sum\limits_{i=0}^{n}C^{i}_{n}=2^{n}i=0∑n​Cni​=2n

证明:

1)当n=1n=1时:

\sum\limits_{i=0}^{n}C^{i}_{n}=C^0_1+C^1_1=2=2^1i=0∑n​Cni​=C10​+C11​=2=21

等式成立。

2)假设当n=k(k\in N_+)n=k(k∈N+​)时\sum\limits_{i=0}^{n}C^{i}_{n}=2^{n}i=0∑n​Cni​=2n 成立, 即\sum\limits_{i=0}^{k}C^{i}_{k}=2^{k}i=0∑k​Cki​=2k

那么当n=k+1n=k+1时:

\text{\ \ \ \ }     \sum\limits_{i=0}^{k+1}C^{i}_{k+1}i=0∑k+1​Ck+1i​

=C^{0}_{k+1}+C^{1}_{k+1}+C^{2}_{k+1}+...+C^{k}_{k+1}+C^{k+1}_{k+1}=Ck+10​+Ck+11​+Ck+12​+...+Ck+1k​+Ck+1k+1​

=C^{0}_{k+1}+(C^{0}_{k}+C^{1}_{k})+(C^{1}_{k}+C^{2}_{k})+...+(C^{k-1}_{k}+C^{k}_{k})+C^{k+1}_{k+1}=Ck+10​+(Ck0​+Ck1​)+(Ck1​+Ck2​)+...+(Ckk−1​+Ckk​)+Ck+1k+1​

=C^{0}_{k}+(C^{0}_{k}+C^{1}_{k})+(C^{1}_{k}+C^{2}_{k})+...+(C^{k-1}_{k}+C^{k}_{k})+C^{k}_{k}=Ck0​+(Ck0​+Ck1​)+(Ck1​+Ck2​)+...+(Ckk−1​+Ckk​)+Ckk​

=2(C^0_k+C^1_k+C^2_k+...+C^k_k)=2(Ck0​+Ck1​+Ck2​+...+Ckk​)

=2\sum\limits_{i=0}^{k}C^{i}_{k}=2i=0∑k​Cki​

=2\times2^k=2×2k

=2^{k+1}=2k+1

此时等式依然成立。假设成立。

故\sum\limits_{i=0}^{n}C^{i}_{n}=2^{n}i=0∑n​Cni​=2n

由此可以得到,\sum\limits_{i=1}^{n}C^{i-1}_{n-1}=2^{n-1}i=1∑n​Cn−1i−1​=2n−1

P2415 集合求和(一道洛谷好题鸭)(虽然可以水过,但有必研究DP)的更多相关文章

  1. P2415 集合求和

    P2415 集合求和显然,一共有2^n个子集,对于其中的一个确定的元素,它不在的集合有2^(n-1),相当于有n-1元素,那么它存在的集合有,2^n-2^(n-1)==2^(n-1),那么集合的和为s ...

  2. 整除分块学习笔记+[CQOI2007]余数求和(洛谷P2261,BZOJ1257)

    上模板题例题: [CQOI2007]余数求和 洛谷 BZOJ 题目大意:求 $\sum^n_{i=1}k\ mod\ i$ 的值. 等等……这题就学了三天C++的都会吧? $1\leq n,k\leq ...

  3. 洛谷 P7718 -「EZEC-10」Equalization(差分转化+状压 dp)

    洛谷题面传送门 一道挺有意思的题,现场切掉还是挺有成就感的. 首先看到区间操作我们可以想到差分转换,将区间操作转化为差分序列上的一个或两个单点操作,具体来说我们设 \(b_i=a_{i+1}-a_i\ ...

  4. Bzoj4753/洛谷P4432 [JSOI2016]最佳团体(0/1分数规划+树形DP)

    题面 Bzoj 洛谷 题解 这种求比值最大就是\(0/1\)分数规划的一般模型. 这里用二分法来求解最大比值,接着考虑如何\(check\),这里很明显可以想到用树形背包\(check\),但是时间复 ...

  5. 洛谷 P3287 - [SCOI2014]方伯伯的玉米田(BIT 优化 DP)

    洛谷题面传送门 怎么题解区全是 2log 的做法/jk,这里提供一种 1log 并且代码更短(bushi)的做法. 首先考虑对于一个序列 \(a\) 怎样计算将其变成单调不降的最小代价.对于这类涉及区 ...

  6. 【题解】洛谷P1373 小a和uim之大逃离(坐标DP)

    次元传送门:洛谷P1373 思路 设f[i][j][t][1/0]表示走到(i,j)时 小a减去uim的差值为t 当前是小a取(0) uim取(1) 那么转移就很明显了 f[i][j][t][]=(f ...

  7. 洛谷 P4125 [WC2012]记忆中的水杉树【扫描线+set+线段树】

    我没有找到能在bzojAC的代码--当然我也WA了--但是我在洛谷过了,那就假装过了吧 minmax线段树一开始写的只能用min更新min,max更新max,实际上是可以互相更新的-- 首先看第二问, ...

  8. 洛谷 P2415 集合求和【数学公式/模拟】

    给定一个集合s(集合元素数量<=30),求出此集合所有子集元素之和. 输入输出格式 输入格式: 集合中的元素(元素<=1000) 输出格式: 和 输入输出样例 输入样例#1: 2 3 输出 ...

  9. 洛谷P2415 集合求和

    题目描述 给定一个集合s(集合元素数量<=30),求出此集合所有子集元素之和. 输入输出格式 输入格式: 集合中的元素(元素<=1000) 输出格式: 和 输入输出样例 输入样例#1: 2 ...

随机推荐

  1. Go-back-N Implementation of reliable data transport (RDT)

    [Author] @ Yubao Liu Tables 1.Overview 2.Design explanation 2.1Implemented Routines 2.2Called Routin ...

  2. Swift3 Xcode8 Ios10 开发笔记

    设置不同subView的层次: //将subView挪到最上边 self.view.bringSubviewToFront(subView) //将subView挪到最下边 self.view.sen ...

  3. 自建windows服务器如何部署egg应用

    1. 使用IE浏览器登陆VPN 2. 远程登陆 3. 在服务器安装最新的node.js,git等 4. 下载源码 > git clone ****.git 5. npm安装依赖 > cd ...

  4. 从比特币、以太坊、libra的不同特点认识move语言

    关于比特币.以太坊.libra,我们知道他们是不同的区块链应用,那么他们的根本差别在哪里呢. 其实,单从白皮书的标题,就可以大概看出三个项目在设计目标上的差异. 比特币的目标是 -- 可编程货币(Pr ...

  5. 关于JQUery.parseJSON()函数的知识札记

    JSON数据也许大家都很陌生,而对我来讲属于半成品,由于项目问题,做web虽然用的是JSON数据格式传输,但是关于解析这一块还真不知道该注意什么,更不知道它是如何解析的,由于最近要把串口通信协议与此一 ...

  6. iOS:探究视图控制器的转场动画

    一.介绍 在iOS开发中,转场动画的使用无处不见,不只是我们自己更多的使用UIViewblock动画实现一个转场动画,其实,在我们实现VC控制器跳转的时候都是转场动画的实现,例如标签栏控制器的切换.模 ...

  7. Numpy 排序和使用索引

    # 导包 import numpy as np 排序 .sort() x = np.arange(16) # array([ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, ...

  8. CSPS模拟 63

    每天都考试都快傻了O_o $T1 Median$ 一看就不能从通项上下手.. 那么就是..给你一个序列..区间中位数.. 对顶堆! 爆调2h,心态炸裂. 据说根据鬼畜的函数定义和$mod<=le ...

  9. NOIP模拟 34

    次芝麻,喝喝喝,长寿花! 什么鬼畜题面...一看就不是什么正经出题人 skyh双双双AK了..太巨了... T1 次芝麻 稍稍手玩就能发现分界点以一个优美的方式跳动 然后就愉快地帮次货们次掉了这个题- ...

  10. HTMLTestRunner加入logging输出

    使用HTMLTestRunner生成html的测试报告的时候,报告中只有console输出,logging的输出无法保存, 如果要在报告中加入每一个测试用例执行的logging信息,则需要改HTMLT ...