HDU 4649 Professor Tian(反状态压缩dp,概率)
本文出自 http://blog.csdn.net/shuangde800
题目链接:点击打开链接
题目大意
初始有一个数字A0, 然后给出A1,A2..An共n个数字,这n个数字每个数字分别有一个操作符,&,|,^
且每个数字出现的概率是pi
如果某个数字出现了,那么就和前面的数字用它的操作符进行位运算。
问最终的期望值是多少?
思路
这题官方题解说是反状态压缩,还是第一次做这种题。
知道了怎么表示状态这题就觉得不难做了,赛后1A。
题解官方的已经很详细了,不再累赘:
反状态压缩——把数据转换成20位的01来进行运算
因为只有20位,而且&,|,^都不会进位,那么一位一位地看,每一位不是0就是1,这样求出每一位是1的概率,再乘以该位的十进制数,累加,就得到了总体的期望。
对于每一位,状态转移方程如下:
f[i][j]表示该位取前i个数,运算得到j(0或1)的概率是多少。
f[i][1]=f[i-1][1]*p[i]+根据不同运算符和第i位的值运算得到1的概率。
f[i][0]同理。
初始状态:f[0][0~1]=0或1(根据第一个数的该位来设置)
每一位为1的期望 f[n][1]
代码
HDU 4649 Professor Tian(反状态压缩dp,概率)的更多相关文章
- hdu 4649 Professor Tian 反状态压缩+概率DP
		
思路:反状态压缩——把数据转换成20位的01来进行运算 因为只有20位,而且&,|,^都不会进位,那么一位一位地看,每一位不是0就是1,这样求出每一位是1的概率,再乘以该位的十进制数,累加,就 ...
 - HDU 4649 - Professor Tian(2013MUTC5-1007)(概率)
		
不知道这题算作什么类型的题目,反正很巧妙,队友小杰想了没一会就搞定了 为了学习这种方法,我也搞了搞,其实思路不难想,位运算嘛,只有0和1,而且该位的运算只影响该位,最多20位,一位一位地计算即可,只需 ...
 - hdu 5025 Saving Tang Monk 状态压缩dp+广搜
		
作者:jostree 转载请注明出处 http://www.cnblogs.com/jostree/p/4092939.html 题目链接:hdu 5025 Saving Tang Monk 状态压缩 ...
 - HDU 4649 Professor Tian (概率DP)
		
Professor Tian Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)To ...
 - HDU 4649 Professor Tian
		
Professor Tian Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) T ...
 - HDU 3681 Prison Break(状态压缩dp + BFS)
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3681 前些天花时间看到的题目,但写出不来,弱弱的放弃了.没想到现在学弟居然写出这种代码来,大吃一惊附加 ...
 - hdu 4649 Professor Tian 多校联合训练的题
		
这题起初没读懂题意,悲剧啊,然后看了题解写完就AC了 题意是给一个N,然后给N+1个整数 接着给N个操作符(只有三种操作 即 或 ,与 ,和异或 | & ^ )这样依次把操作符插入整 ...
 - HDU 6125 Free from square 状态压缩DP + 分组背包
		
Free from square Problem Description There is a set including all positive integers that are not mor ...
 - HDU 1074 Doing Homework【状态压缩DP】
		
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1074 题意: 给定作业截止时间和完成作业所需时间,比截止时间晚一天扣一分,问如何安排作业的顺序使得最 ...
 
随机推荐
- Gradle设置代理
			
在本地仓库路径下(如果没有修改的话默认C:\Users\用户名\.gradle),或者项目下,新建一个文件gradle.properties systemProp.http.proxyHost=网址 ...
 - MongoDB官方文档结构
			
本文展示MongoDB 3.6.4.0的官方Server文档的结构图——一眼可见完整的知识脉络图.不过,MongoDB除了Server的文档外,还有DRIVERS.CLOUD.TOOLS.DUIDES ...
 - 【小程序开发总结】微信小程序开发常用技术方法总结
			
1.获取input的值 <input bindinput="bindKeyInput" placeholder="输入同步到view中"/> b ...
 - ibm x3550m4 开启cpu高性能模式
			
1.必须进bios里调整,和调整超线程一样,重启服务器按F1进bios界面,选择system settings 2.选择最大性能模式:Operating Modes>Choose Operati ...
 - 开启nginx目录文件列表功能
			
ngx_http_autoindex_module 此模块用于自动生成目录列表,ngx_http_autoindex_module只在 ngx_http_index_module模块未找到索引文件时 ...
 - LeetCode282. Expression Add Operators
			
Given a string that contains only digits 0-9 and a target value, return all possibilities to add bin ...
 - ObjectInputStream与ObjectOutputStream
			
雇员类 package io; import java.io.Serializable; @SuppressWarnings("serial") public class Emp ...
 - pymongo处理正则表达式的情况
			
在python里使用pymongo处理mongodb数据库,在插入或者查询的时候,我们有时需要使用操作符号,如set,in, 具体操作符的可以参考 https://docs.mongodb.com/ ...
 - Android开发——子线程操作UI的几种方法(待续)
			
方法2 Handler andler mHandler = new Handler() { @Override public void handleMessage(Message msg) { su ...
 - 操作系统基础梳理--进程&线程
			
1.举个栗子 1.1.知乎一形象例子 [摘自知乎]比如说十几年前,马化腾在写QQ,假设他那个时候不懂多进程多线程.然后他就开始写啦,这玩意儿不简单吗,不就是用户输入什么,把信息打包发到另一个用户,再显 ...