bzoj 2073 暴力
2073: [POI2004]PRZ
Time Limit: 10 Sec  Memory Limit: 64 MB
Submit: 442  Solved: 327
[Submit][Status][Discuss]
Description
队伍里每个人过桥都需要特定的时间,当一批队员过桥时时间应该算走得最慢的那一个,每个人也有特定的重量,我们想知道如何分批过桥能使总时间最少.
Input
w <= 400) 和 n – 队员总数(1 <= n <= 16). 接下来n 行每行两个数分别表示: t –
该队员过桥所需时间(1 <= t <= 50) 和 w – 该队员的重量(10 <= w <= 100).
Output
Sample Input
24 60
10 40
18 50
Sample Output
HINT
Source
这道题目的状态压缩暴力枚举转移的复杂度是∑(Cn,i * 2^i)渐进与3^n
这个我不知道,考试是打表找复杂度吧。
#pragma GCC optimize(2)
#pragma G++ optimize(2)
#include<iostream>
#include<algorithm>
#include<cmath>
#include<cstdio>
#include<cstring> #define N 70007
#define inf 1000000007
using namespace std;
inline int read()
{
int x=,f=;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-;ch=getchar();}
while(isdigit(ch)){x=(x<<)+(x<<)+ch-'';ch=getchar();}
return x*f;
} int w,n;
int weight[N],tim[N],f[N];
struct Node
{
int t,w;
}a[]; void dfs(int dep,int now,int slow,int zl)
{
if(dep==n)
{
weight[now]=zl;
tim[now]=slow;
return;
}
dep++;
dfs(dep,now<<|,max(slow,a[dep].t),zl+a[dep].w);
dfs(dep,now<<,slow,zl);
}
int main()
{
w=read(),n=read();
for (int i=;i<=n;i++)a[i].t=read(),a[i].w=read();
dfs(,,,);
f[]=;int up=<<n;
for (int i=;i<up;i++)f[i]=inf;
for (int i=;i<up;i++)
{
for (int j=i;j;j=(j-)&i)
if(weight[j]<=w) f[i]=min(f[i],f[i^j]+tim[j]);
}
printf("%d\n",f[up-]);
}
bzoj 2073 暴力的更多相关文章
- Bzoj: 2073 [POI2004]PRZ 题解
		2073: [POI2004]PRZ Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 401 Solved: 296[Submit][Status][D ... 
- bzoj 1028 暴力枚举判断
		昨天梦到这道题了,所以一定要A掉(其实梦到了3道,有两道记不清了) 暴力枚举等的是哪张牌,将是哪张牌,然后贪心的判断就行了. 对于一个状态判断是否为胡牌,1-n扫一遍,然后对于每个牌,先mod 3, ... 
- BZOJ 2073: [POI2004]PRZ( 状压dp )
		早上这道题没调完就去玩NOI网络同步赛了.... 状压dp , dp( s ) 表示 s 状态下所用的最短时间 , 转移就直接暴力枚举子集 . 可以先预处理出每个状态下的重量和时间的信息 . 复杂度是 ... 
- bzoj 3620 暴力KMP
		十分暴力的KMP,枚举左端点,在向右侧推进的同时,取较小的la保证条件,n方暴力 #include<bits/stdc++.h> #define rep(i,j,k) for(int i= ... 
- bzoj 3916 暴力哈希
		暴力的哈希,注意: 将一个串当作另一个串的前缀,需要乘上p[len],len=后面串的长度 这是自己的代码,拿数据在本地测A掉了,但是bz上wa了??bz换数据了难道?? #include<cs ... 
- BZOJ 2073 [POI2004]PRZ(状压DP)
		[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2073 [题目大意] 任何时候队伍在桥上的人都不能超过一定的限制. 所以这只队伍过桥时只 ... 
- bzoj 2073: [POI2004]PRZ
		2073: [POI2004]PRZ Description 一只队伍在爬山时碰到了雪崩,他们在逃跑时遇到了一座桥,他们要尽快的过桥. 桥已经很旧了, 所以它不能承受太重的东西. 任何时候队伍在桥上的 ... 
- bzoj 1493 暴力
		我们可以枚举每个点,然后求出这个点到其余点最小消耗的代价,求出比t小的且距离最大的更新答案. /**************************************************** ... 
- bzoj 1800 暴力枚举
		直接暴力枚举四个点,然后判断是否能组成矩形就行了 注意枚举的点的标号从小到大,保证不重复枚举 /**************************************************** ... 
随机推荐
- Linux - 在Ubuntu下永久修改主机名
			查看主机名 root@jiqing:~# hostname jiqing 1.临时生效 root@jiqing:~# hostname jq root@jiqing:~# hostname jq 重新 ... 
- tone()函数的有趣的使用案例
			tong()除了可以驱动蜂鸣器之外,还可以驱动步进电机(测试很好用) 一个引脚上产生一个特定频率的方波(%占空比).持续时间可以设定,否则波形会一直产生直到调用noTone()函数.该引脚可以连接压电 ... 
- elasticsearch的集中常见操作
			1.引入dependency <dependency> <groupId>org.springframework.data</groupId> <artifa ... 
- nginx把POST转GET请求解决405问题
			405重定向,然后把POST转GET upstream local { server 10.0.1.11:81; } server { listen 81; server_name testf.xxx ... 
- Activity组件安全(下)
			什么是Activity劫持 简单的说就是APP正常的Activity界面被恶意攻击者替换上仿冒的恶意Activity界面进行攻击和非法用途.界面劫持攻击通常难被识别出来,其造成的后果不仅会给用户带来严 ... 
- SpringBoot整合Redis、ApachSolr和SpringSession
			SpringBoot整合Redis.ApachSolr和SpringSession 一.简介 SpringBoot自从问世以来,以其方便的配置受到了广大开发者的青睐.它提供了各种starter简化很多 ... 
- scanf后面跟一个getchar
			scanf(“%d",&a): if(getchar() != '\n') printf();else printf(); 这种情况下,我有点迷惑,就做了个实验,结论是: 1.当输完 ... 
- Python Selenium + phantomJS 模拟登陆教务管理系统  “抢课”
			# _*_coding:utf-8_*_ from selenium import webdriver from selenium.webdriver.common.action_chains imp ... 
- 基于redis的cas实现
			cas是我们常用的一种解决并发问题的手段,小到CPU指令集,大到分布式存储,都能看到cas的影子.本文假定你已经充分理解一般的cas方案,如果你还不知道cas是什么,请自行百度 我们在进行关系型数据库 ... 
- python的logging模块
			python提供了一个日志处理的模块,那就是logging 导入logging模块使用以下命令: import logging logging模块的用法: 1.简单的将日志打印到屏幕上 import ... 
