Chinese Dialects__总结
来源:互联网 发布:java工作流引擎 开源 编辑:程序博客网 时间:2024/06/05 09:05
http://acm.hust.edu.cn/vjudge/contest/view.action?cid=34629#problem/D
http://acm.timus.ru/problem.aspx?space=1&num=1964
看到这道题的时候,题目已经被贴上了容斥的标签。自己就什么都不管,一头扎到那个方向,自己最后还想出来了一个看似正确的想法,可笑至极。。。。
我的想法:分奇偶的情况,奇数:n = ∩(1) - ∩(2) + ∩(3) + ..... +∩(k)此时∩(1)>=n,式子可以分开成若干项相加,那么除过∩(n)之外的项尽可能的大。
---------华丽的分割线--------之后开始脑残。。。。。
认为∩(n+1)与∩(n)存在一个限制关系。。。。然后就一直陷入死循环,WA了两次之后才觉得应该是想的不对
这个时候应该换一种思路的,直到最后队友A了这个题,我好想也不太明白∩(n+1)与∩(n)的限制关系 (除了>=关系之外)
缅怀一下这个奇葩的思路。
容斥是考虑了多个集合相交的情况,使得问题变得更加复杂(我是这样觉得的),如果不是题目中明确告诉了多个集合相交的情况,尽量避免将题目的问题考虑成互相有影响的情况。还是按照通常的思路,将题目分解。
以后做题应该多注意思路的灵活性,不要总是一直纠结一个思路,思路还是太弱了。。。。
明显可以知道这个题目不难,已经很多人秒了的,就应该能大概估计出来这个题目的程度。。。还是需要灵活。。。。
此题目有两种解法:
1.贪心 --> 不妨设会Ki种语言的人有Xi人,那么sum = sigma(Ki * Xi ) 此时考虑一下对于会k-1种语言的人儿,他的系数除了k意外是最大的,如果都是会k-1种语言的人,即此时的人数为n * (k - 1),此时是没有会k种语言人时候总人数最多的时候,若仍小于sum,那么必然要有会k种语言的人;若直接大于sum,那么一定不用有会k种语言的人;
这个思路还是比较简单的,不用数学什么原理
2.类似小容斥+贪心 ---> 每次考虑前两个种类的人,贪心一下,假如至少会前两个语言的人最少,那么结果也会减少。也就是 a[0] + a[1] - a[0] ∪ a[1]最小,即a[0] ∪ a[1] 最大,最大的情况就是总人数,那么一直贪心即可
- Chinese Dialects__总结
- **"Chinese"
- chinese
- 语文(Chinese)
- Chinese Zodiac
- Chinese Dragon
- XML(Chinese)
- chinese input
- chinese linux
- support chinese
- Written Chinese
- chinese.php
- android chinese
- Chinese.java
- Chinese Mahjong
- Chinese Food
- Chinese Mahjong
- Chinese Mahjong
- 安装IETester(解决不能使用IE6,并安装IE10)
- 高性能的MySQL(1)锁和MVCC
- DNS服务器
- android UI 工具
- 如何制作Jar包并在android中调用jar包
- Chinese Dialects__总结
- 在SHTML中通过SSI指令实现文件动态包含
- 高性能的MySQL(2)慢查询
- STM32 IAP 在线升级详解
- Java Language and Virtual Machine Specifications
- Android横屏竖屏切换的问题
- android 电源管理PowerManager介绍
- oracle 10支持正则表达式REGEXP_LIKE(content,'[[:digit:]]'))
- eclipse tomcat内存溢出