CSP-2020倒计时:36天

【SHOI2008】JZOJ2020年9月5日提高组 循环的债务

题目

Description

Alice、Bob和Cynthia总是为他们之间混乱的债务而烦恼,终于有一天,他们决定坐下来一起解决这个问题。不过,鉴别钞票的真伪是一件很麻烦的事情,于是他们决定要在清还债务的时候尽可能少的交换现金。

比如说,Alice欠Bob 10元,而Cynthia和他俩互不相欠。现在假设Alice只有一张50元,Bob有3张10元和10张1元,Cynthia有3张20元。一种比较直接的做法是:Alice将50元交给Bob,而Bob将他身上的钱找给Alice,这样一共就会有14张钞票被交换。但这不是最好的做法,最好的做法是:Alice把50块给Cynthia,Cynthia再把两张20给Alice,另一张20给Bob,而Bob把一张10块给C,此时只有5张钞票被交换过。

没过多久他们就发现这是一个很棘手的问题,于是他们找到了精通数学的你为他们解决这个难题。

Input

输入的第一行包括三个整数:x1、x2、x3(-1,000≤x1,x2,x3≤1,000),其中

x1代表Alice欠Bob的钱(如果x1是负数,说明Bob欠了Alice的钱)

x2代表Bob欠Cynthia的钱(如果x2是负数,说明Cynthia欠了Bob的钱)

x3代表Cynthia欠Alice的钱(如果x3是负数,说明Alice欠了Cynthia的钱)

接下来有三行,每行包括6个自然数:

a100,a50,a20,a10,a5,a1

b100,b50,b20,b10,b5,b1

c100,c50,c20,c10,c5,c1

a100表示Alice拥有的100元钞票张数,b50表示Bob拥有的50元钞票张数,以此类推。另外,我们保证有a10+a5+a1≤30,b10+b5+b1≤30,c10+c5+c1≤30,而且三人总共拥有的钞票面值总额不会超过1,000。

Output

如果债务可以还清,则输出需要交换钞票的最少张数;如果不能还清,则输出“impossible”(注意单词全部小写,输出到文件时不要加引号)。

Sample Input

10 0 0

0 1 0 0 0 0

0 0 0 3 0 10

0 0 3 0 0 0

Sample Output

5

Hint

对于100%的数据,x1、x2、x3 ≤ |1,000|。

题解

注明:以下的\(A\)表示\(Alice\),\(B\)表示\(Bob\),\(C\)表示\(Cynthia\)

发现钱的总量是不变的

思考\(DP\)

设\(f[i][j][k]\)表示考虑了前\(i\)种币值(从大到小),\(A\)有\(j\)元,\(B\)有\(k\)元

因为钱的总数不变,那么就可以算出\(C\)的钱

既然总数不变,那么就可以枚举第\(i\)种钱经过交换后\(A\)有多少,\(B\)有多少,算出\(C\)有多少,计算一下交换次数,转移即可

Code

#include<bits/stdc++.h>
using namespace std;
int x1,x2,x3,all,c1,c2,c3,z,tot,now,f[10][1005][1005],cost[7]={0,100,50,20,10,5,1},a[5][10];
int read()
{
int res=0,fh=1;char ch=getchar();
while ((ch<'0'||ch>'9')&&ch!='-') ch=getchar();
if (ch=='-') fh=-1,ch=getchar();
while (ch>='0'&&ch<='9') res=(res<<1)+(res<<3)+(ch-'0'),ch=getchar();
return res*fh;
}
int main()
{
x1=read();x2=read();x3=read();
for (int i=1;i<=3;++i)
for (int j=1;j<=6;++j)
{
a[i][j]=read();
all+=a[i][j]*cost[j];
}
for (int i=1;i<=6;++i)
c1+=a[1][i]*cost[i],c2+=a[2][i]*cost[i];
if (c1-x1+x3>all||c2-x2+x1>all||all-c1-c2-x3+x2>all)
{
printf("impossible\n");
return 0;
}
memset(f,0X3f3f3f,sizeof(f));
f[0][c1][c2]=0;
for (int i=1;i<=6;++i)
for (int j=0;j<=all;++j)
for (int k=0;j+k<=all;++k)
{
if (f[i-1][j][k]>1e9) continue;
tot=a[1][i]+a[2][i]+a[3][i];
for (int x=0;x<=tot;++x)
for (int y=0;y+x<=tot;++y)
{
z=tot-x-y;
now=(abs(a[1][i]-x)+abs(a[2][i]-y)+abs(a[3][i]-z))/2;
if (j-(a[1][i]-x)*cost[i]+k-(a[2][i]-y)*cost[i]>all) continue;
if (j-(a[1][i]-x)*cost[i]<0||k-(a[2][i]-y)*cost[i]<0) continue;
f[i][j-(a[1][i]-x)*cost[i]][k-(a[2][i]-y)*cost[i]]=min(f[i][j-(a[1][i]-x)*cost[i]][k-(a[2][i]-y)*cost[i]],f[i-1][j][k]+now);
}
}
if (f[6][c1-x1+x3][c2-x2+x1]>1e9)
{
printf("impossible\n");
return 0;
}
printf("%d\n",f[6][c1-x1+x3][c2-x2+x1]);
return 0;
}

【SHOI2008】JZOJ2020年9月5日提高组 循环的债务的更多相关文章

  1. JZOJ2020年8月11日提高组T4 景点中心

    JZOJ2020年8月11日提高组T4 景点中心 题目 Description 话说宁波市的中小学生在镇海中学参加计算机程序设计比赛,比赛之余,他们在镇海中学的各个景点参观.镇海中学共有n个景点,每个 ...

  2. JZOJ2020年8月11日提高组T3 页

    JZOJ2020年8月11日提高组T3 页 题目 Description 战神阿瑞斯听说2008年在中华大地上,将举行一届规模盛大的奥林匹克运动会,心中顿觉异常兴奋,他想让天马在广阔的天空上,举行一场 ...

  3. JZOJ2020年8月11日提高组T2 宝石

    JZOJ2020年8月11日提高组T2 宝石 题目 Description 见上帝动了恻隐之心,天后也想显示一下慈悲之怀,随即从口袋中取出一块魔术方巾,让身边的美神维纳斯拿到后堂的屏风上去试试,屏风是 ...

  4. JZOJ2020年8月11日提高组T1 密码

    JZOJ2020年8月11日提高组T1 密码 题目 Description 在浩浩茫茫的苍穹深处,住着上帝和他的神仆们,他们闲谈着下界的凡人俗事,对人世间表现的聪明智慧,大加赞赏.今天他们正在观赏大地 ...

  5. JZOJ2020年8月11日提高组反思

    JZOJ2020年8月11日提高组反思 T1 看到题 啊这?! 我看错了吗??? 我理解错题了吗?? 好吧没有-- 高精度模板题,不用多说 T2 看到这种矩阵的问题 以为是前缀和搞事情 结果呢 扫描线 ...

  6. JZOJ2020年9月5日提高组反思

    JZOJ2020年9月5日提高组反思 T1 考试的时候没有头绪,就打了个暴力,愉快的拿到了10分的\(impossible\) 正解是\(DP\),设\(f[i][j][k]\)表示地\(i\)种币值 ...

  7. 【GDOI2014模拟】JZOJ2020年8月14日提高组 服务器

    [GDOI2014模拟]JZOJ2020年8月14日提高组 服务器 题目 Time and Memory Limits Description 我们需要将一个文件复制到n个服务器上,这些服务器的编号为 ...

  8. JZOJ2020年8月14日提高组反思

    JZOJ2020年8月14日提高组反思 T1 看到题 一脸:我是谁,我在哪,我要干啥 看到字符串凉一半 还有查询修改 想到线段树但不会建模 暴力安排 T2 一开始觉得:水题 然后啪啪打脸 空间小,数据 ...

  9. 【GDKOI2014】JZOJ2020年8月13日提高组T4 内存分配

    [GDKOI2014]JZOJ2020年8月13日提高组T4 内存分配 题目 Description Input Output 输出m行,每行一个整数,代表输入中每次程序变化后系统所需要的空闲内存单位 ...

随机推荐

  1. 851. Loud and Rich —— weekly contest 87

    851. Loud and Rich 题目链接:https://leetcode.com/problems/loud-and-rich/description/ 思路:有向图DFS,记录最小的quie ...

  2. linux中配置yum文件

    yum简介:yum的宗旨是自动化地升级,安装/移除rpm包,收集rpm包的相关信息,检查依赖性并自动提示用户解决. yum的关键之处是要有可靠的repository,顾名思义,这是软件的仓库,它可以是 ...

  3. ashx将datatable返回json数据

    1.直接使用JsonConvert.SerializeObject().将datatable放入  输出字符串 下面是测试:用webform+ashx作为接口. public class GetJso ...

  4. Oracle(第二天)

    一.外键(foreign key):constraint , refenerces 例如:sno number(7) constraint fk_sno references student(sno) ...

  5. 80%人会答错的JS基础面试题

    这套题第一道题难度最大,我第一遍的回答居然也错的,我悲观估计80%的JavaScript从业人员都答不完全准确 []==![] 得到什么? false, 你还需要看看基础 true, 恭喜你答对了,你 ...

  6. linux netfilter ----iptable_filter

    内核中将filter模块被组织成了一个独立的模块,每个这样独立的模块中都有个类似的init()初始化函数:首先来看一下filter模块是如何将自己的钩子函数注册到netfilter所管辖的几个hook ...

  7. yum 的一些问题总结

    1. yum 只删除目标,不删除依赖 rpm -e --nodeps xxx 2.yum remove 出错 报错 Error: Cannot retrieve repository metadata ...

  8. Python_PyQt5_库

    QtQWidgets  小组件(暂无资料,但是Python中做窗口/网页时用的很多  *-*)  QtCore 模块包括了核心的非GUI功能,该模块用来对时间.文件.目录.各种数据类型.流.网址.媒体 ...

  9. C# 9 record 并非简单属性 POCO 的语法糖

    C# 9 record 并非简单属性 POCO 的语法糖 最近升级专案到大统一 .NET 5 并使用 C#9 语法尝试改写套件,发现之前以为 record 只是简单属性 POCO 的简化语法糖的认知是 ...

  10. JS处理Long类型精度丢失问题

    解决方式一 json注解 public class ProductVo {​   @JsonSerialize(using=ToStringSerializer.class)   private Lo ...