【BZOJ1021】[SHOI2008]循环的债务(动态规划)
【BZOJ1021】[SHOI2008]循环的债务(动态规划)
题面
题解
感觉以前的题目都好小清新啊,我这种智商丢失的选手完全写不动。
这题看着就像一个\(dp\),并且我们发现每种币值之间是独立的,而且起始状态和终止状态同样已知。
设\(f[i][j][k]\)表示只交换前\(i\)种币值的情况下,第一个人拥有\(j\)元,第二个人拥有\(k\)元时的最小交换次数。抓住不变量是钱的总和不变,所以第三个人手中拥有的钱的总和就是三个人的总和减去前两个人的钱的总和。每次两重循环枚举转移多少钱即可。
然而\(bzoj\)一秒总时限,让我怎么跑。。。
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
using namespace std;
#define MAX 1010
inline int read()
{
int x=0;bool t=false;char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-')t=true,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
return t?-x:x;
}
int x1,x2,x3,s1,s2,sum;
int b[7]={0,100,50,20,10,5,1};
int a[4][8],f[8][MAX][MAX];
void cmin(int &x,int y){x=min(x,y);}
int main()
{
x1=read();x2=read();x3=read();
for(int i=1;i<=3;++i)
for(int j=1;j<=6;++j)
sum+=(a[i][j]=read())*b[j];
for(int i=1;i<=6;++i)s1+=a[1][i]*b[i],s2+=a[2][i]*b[i];
if(s1-x1+x3>sum||s2-x2+x1>sum||sum-s1-s2-x3+x2>sum){puts("impossible");return 0;}
memset(f,63,sizeof(f));f[0][s1][s2]=0;
for(int i=1;i<=6;++i)
for(int j=0;j<=sum;++j)
for(int k=0;j+k<=sum;++k)
{
if(f[i-1][j][k]>1e9)continue;
int tot=a[1][i]+a[2][i]+a[3][i];
for(int x=0;x<=tot;++x)
for(int y=0;x+y<=tot;++y)
{
int z=tot-x-y;
int s=(abs(a[1][i]-x)+abs(a[2][i]-y)+abs(a[3][i]-z))/2;
if(j-(a[1][i]-x)*b[i]+k-(a[2][i]-y)*b[i]>sum)continue;
if(j-(a[1][i]-x)*b[i]<0||k-(a[2][i]-y)*b[i]<0)continue;
cmin(f[i][j-(a[1][i]-x)*b[i]][k-(a[2][i]-y)*b[i]],f[i-1][j][k]+s);
}
}
int ans=f[6][s1-x1+x3][s2-x2+x1];
if(ans>1e9)puts("impossible");
else printf("%d\n",ans);
return 0;
}
【BZOJ1021】[SHOI2008]循环的债务(动态规划)的更多相关文章
- BZOJ1021 [SHOI2008]循环的债务
Description Alice.Bob和Cynthia总是为他们之间混乱的债务而烦恼,终于有一天,他们决定坐下来一起解决这个问题. 不过,鉴别钞票的真伪是一件很麻烦的事情,于是他们决定要在清还债务 ...
- BZOJ1021 SHOI2008循环的债务
dp模拟即可. d[i][j][k]表示使用前i种面值,1号手里钱为j,2号手里钱为k时最少操作数 使用滚动数组压缩空间 #include <cstdio> #include <cs ...
- [bzoj1021][SHOI2008]Debt 循环的债务 (动态规划)
Description Alice. Bob和Cynthia总是为他们之间混乱的债务而烦恼,终于有一天,他们决定坐下来一起解决这个问题.不过,鉴别钞票的真伪是一件很麻烦的事情,于是他 们决定要在清还债 ...
- [SHOI2008]循环的债务
Description Alice.Bob和Cynthia总是为他们之间混乱的债务而烦恼,终于有一天,他们决定坐下来一起解决这个问题. 不过,鉴别钞票的真伪是一件很麻烦的事情,于是他们决定要在清还债务 ...
- BZOJ.1021.[SHOI2008]循环的债务(DP)
题目链接 不同面额的钞票是可以分开考虑的. ↑其实并不很明白具体(证明?),反正是可以像背包一样去做. f[x][i][j]表示用前x种面额钞票满足 A有i元 B有j元 (C有sum-i-j)所需交换 ...
- 洛谷 P4026 [SHOI2008]循环的债务
水水的dp 设f[i][a][b]表示交换完前i种面值的钞票,第一个人有a元,第二个人有b元的最小代价 直接转移就行了 需要注意的是算的式子 第1个人\(\Delta A\),第二个人\(\Delta ...
- [luogu4026 SHOI2008]循环的债务 (DP)
传送门 吐槽洛谷难度标签qwq Solution 显然是一道神奇的DP,由于总钱数不变,我们只需要枚举前两个人的钱数就可知第三个人的钱数 DP的时候先枚举只用前k个币种,然后枚举前两个人的钱数,然后枚 ...
- bzoj1021 [SHOI2008]Debt 循环的债务
前天打了一场比赛,让我知道自己Dp有多弱了,伤心了一天,没刷bzoj. 昨天想了一天,虽然知道几何怎么搞,但我还是不敢写,让我知道自己几何有多弱了,伤心了一天,没刷bzoj 1021: [SHOI20 ...
- bzoj千题计划111:bzoj1021: [SHOI2008]Debt 循环的债务
http://www.lydsy.com/JudgeOnline/problem.php?id=1021 如果A收到了B的1张10元,那么A绝对不会把这张10元再给C 因为这样不如B直接给C优 由此可 ...
随机推荐
- 一个有趣的异步时序逻辑电路设计实例 ——MFM调制模块设计笔记
本文从本人的163博客搬迁至此. MFM是改进型频率调制的缩写,其本质是一种非归零码,是用于磁介质硬盘存储的一种调制方式.调制规则有两句话,即两个翻转条件: 1.为1的码元在每个码元的正中进行一次翻转 ...
- 20155310 《网络攻防》Exp4 恶意代码分析
20155310 <网络攻防>Exp4 恶意代码分析 基础问题 1.如果在工作中怀疑一台主机上有恶意代码,但只是猜想,所有想监控下系统一天天的到底在干些什么.请设计下你想监控的操作有哪些, ...
- python 画圆
import numpy as np import matplotlib.pyplot as plt # ========================================== # 圆的 ...
- Scala学习(二)--- 控制结构和函数
控制结构和函数 摘要: 本篇主要学习在Scala中使用条件表达式.循环和函数,你会看到Scala和其他编程语言之间一个根本性的差异.在Java或C++中,我们把表达式(比如3+4)和语句(比如if语句 ...
- SQL SERVER 2008R2 安装问题
背景 今天帮可以安装数据库.操作系统是windows server 2012 标准版, 安装SQL SERVER 2008R2 . 运行安装程序,提示如下 这是因为两者之间存在兼容性问题. ...
- 树莓派3b安装Nginx和php7和百度语音合成模块
1.安装sox系统mp3音频播放模块(项目需要) sudo apt-get install lame sudo apt-get install sox sudo apt-get install lib ...
- 使用plumbing命令来深入理解git add和git commit的工作原理
前言: plumbing命令 和 porcelain命令 git中的命令分为plumbing命令和porcelain命令: porcelain命令就是我们常用的git add,git commit等命 ...
- Unity3D工程全资源自动检测系统
是什么 这系统到底是个啥 本系统主要用于自动监测与检测各类型资源是否正常及满足指定规范,并在第一时间把出现的问题输出到控制台与保存到文件,以供对应的负责人及时修正. 为什么 你可能经常遇到的问题 资源 ...
- 散列(Hash)表入门
一.概述 以 Key-Value 的形式进行数据存取的映射(map)结构 简单理解:用最基本的向量(数组)作为底层物理存储结构,通过适当的散列函数在词条的关键码与向量单元的秩(下标)之间建立映射关系 ...
- 1065 A+B and C
同样是一题会产生溢出的题,不同的是这个用大数类很麻烦,因为有负数的可能性 不妨利用溢出的特性来解题:两个整数和为负数 或者 两个负数和为正数,那么就溢出了. #include<bits/stdc ...