题面

相信英文题面也很好理解

x

\tt x

x 个红糖,

y

\tt y

y 个蓝糖。每一个礼包里面要么有

a

\tt a

a 个红糖+

b

\tt b

b 个蓝糖,要么是

a

\tt a

a 个蓝糖+

b

\tt b

b 个红糖。

问最多能打多少份礼包。

T

1

0

4

\tt T\leq 10^4

T≤104 组数据,

1

x

,

y

,

a

,

b

1

0

9

\tt1\leq x,y,a,b\leq10^9

1≤x,y,a,b≤109 。

题解

Solution #1

不难发现答案具有包含性,能打

n

\tt n

n 份就一定能打

n

1

\tt n-1

n−1 份。

交换,令

a

b

\tt a\geq b

a≥b,那么每打包一份礼包,

x

\tt x

x 和

y

\tt y

y 都至少会减少

b

\tt b

b。

直接二分答案

s

\tt s

s,那么在

x

,

y

s

b

\tt x,y\geq s\cdot b

x,y≥s⋅b 的前提下,再把

x

\tt x

x 和

y

\tt y

y 都减去

s

b

\tt s\cdot b

s⋅b 后,相当于在

x

,

y

\tt x,y

x,y 中只用找单独的

s

\tt s

s 个

a

b

\tt a-b

a−b 就行了(

{

x

,

y

}

\tt\{x,y\}

{x,y} 变成了

{

x

s

b

,

y

s

b

}

\tt\{x-sb,y-sb\}

{x−sb,y−sb},

{

a

,

b

}

\tt\{a,b\}

{a,b} 变成了

{

a

b

,

0

}

\tt\{a-b,0\}

{a−b,0},其中一个为 0 了,两种糖果不再绑定),这等价于此时

a

=

b

\tt a=b

a=b 或者

x

a

b

+

y

a

b

s

\tt\left\lfloor\frac{x}{a-b}\right\rfloor+\left\lfloor\frac{y}{a-b}\right\rfloor\geq s

⌊a−bx​⌋+⌊a−by​⌋≥s 。

直到这里,都没怎么用脑子。

7

m

i

n

\tt7~min

7 min 过掉,总复杂度

O

(

T

log

)

\tt O(T\log)

O(Tlog),速度还行,

31

m

s

\tt31~ms

31 ms。

CODE

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define MAXN 100005
#define ENDL putchar('\n')
#define LL long long
#define DB double
#define lowbit(x) ((-x) & (x))
LL read() {
LL f = 1,x = 0;char s = getchar();
while(s < '0' || s > '9') {if(s=='-')f = -f;s = getchar();}
while(s >= '0' && s <= '9') {x=x*10+(s-'0');s = getchar();}
return f * x;
}
int n,m,i,j,s,o,k;
int X,Y,A,B;
bool check(int md) {
int x=X,y=Y,a=A,b=B;
if(x < md*1ll*B || y < md*1ll*B) return 0;
x -= md*1ll*B; y -= md*1ll*B; a -= b;
if(a == 0) return 1;
return x/a + y/a >= md;
}
int main() {
int T = read();
while(T --) {
X = read();Y = read();
A = read();B = read();
if(X < Y) swap(X,Y);
if(A < B) swap(A,B);
int as = 0;
for(int i = 30;i >= 0;i --) {
if(as+(1<<i) <= 1000000000 && check(as+(1<<i))) {
as += (1<<i);
}
}
printf("%d\n",as);
}
return 0;
}

Solution #2

不妨交换,令

x

y

,

a

b

\tt x\geq y,a\geq b

x≥y,a≥b 。

然后利用一定的贪心思路,不难发现,最优情况下

(

a

,

b

)

\tt(a,b)

(a,b) 的个数一定不小于

(

b

,

a

)

\tt(b,a)

(b,a)。换言之,我们可以认为有若干个权重为 1 的礼包

(

a

,

b

)

\tt(a,b)

(a,b),以及若干个权重为 2 的礼包

(

a

+

b

,

b

+

a

)

\tt(a+b,b+a)

(a+b,b+a).

先特判

a

=

b

\tt a=b

a=b 的情况,再继续讨论。

为了尽量地利用糖果,使之剩下的最少(每个礼包固定消耗

a

+

b

\tt a+b

a+b,因此剩下最少一定意味着礼包最多),那么就要尽量使最终的

x

y

\tt|x-y|

∣x−y∣ 最小化。由于每一份礼包 1 都能减少差值

a

b

\tt a-b

a−b ,那么我们就令礼包

(

a

,

b

)

\tt(a,b)

(a,b) 的个数为

x

y

a

b

\tt\left\lfloor\frac{x-y}{a-b}\right\rfloor

⌊a−bx−y​⌋ ,然后再利用剩下的求出礼包 2 的个数、贡献。

为了调整出正确答案,我们还得求一求礼包 1 个数为

x

y

a

b

+

1

\tt\left\lfloor\frac{x-y}{a-b}\right\rfloor+1

⌊a−bx−y​⌋+1 的情况,再取更优值。毕竟有些边角情况,原先的下取整是考虑不到的。

时间复杂度

O

(

T

)

\tt O(T)

O(T) ,写得一般的还是

31

m

s

\tt31~ms

31 ms,而且想的比较久。

CODE(by SharpnessⅤ)

#include<bits/stdc++.h>
#define rep(i,a,b) for(int i=a;i<=b;i++)
#define pre(i,a,b) for(int i=a;i>=b;i--)
#define N 500005
using namespace std;
int x,y,a,b;
void solve(){
scanf("%d%d%d%d",&x,&y,&a,&b);
if(x>y)swap(x,y);if(a>b)swap(a,b);
if(x<a||y<b){puts("0");return ;}
int res=y-x,lim=b-a;
if(!lim){
printf("%d\n",min(x,y)/a);
return ;
}
int cur=min(res/lim,min(x/a,y/b));
x-=cur*a,y-=cur*b;int ans=cur+min(x,y)/(a+b)*2;
if(x>=a&&y>=b)x-=a,y-=b,cur++;
printf("%d\n",max(ans,cur+min(x,y)/(a+b)*2));
}
int main(){
int T;scanf("%d",&T);
while(T--)solve();
return 0;
}

[CF1538G] Gift Set (数学简单题)的更多相关文章

  1. hihoCoder #1234 : Fractal(数学简单题)

    时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 This is the logo of PKUACM 2016. More specifically, the logo i ...

  2. PJ考试可能会用到的数学思维题选讲-自学教程-自学笔记

    PJ考试可能会用到的数学思维题选讲 by Pleiades_Antares 是学弟学妹的讲义--然后一部分题目是我弄的一部分来源于洛谷用户@ 普及组的一些数学思维题,所以可能有点菜咯别怪我 OI中的数 ...

  3. acm.njupt 1001-1026 简单题

    点击可展开上面目录 Acm.njupt 1001-1026简单题 第一页许多是简单题,每题拿出来说说,没有必要,也说不了什么. 直接贴上AC的代码.初学者一题题做,看看别人的AC代码,寻找自己的问题. ...

  4. 天哪!毫无思绪!令人感到恐惧的数学(水题?)(TOWQs)

    这道题的题目描述灰常简单,第一眼看以为是一道十分水的题目: 但是!!!(我仔细一看也没有发现这背后隐藏着可怕的真相~) 下面给出题目描述: 给出一个整数x,你可以对x进行两种操作.1.将x变成4x+3 ...

  5. BZOJ 2683: 简单题

    2683: 简单题 Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 913  Solved: 379[Submit][Status][Discuss] ...

  6. 【BZOJ-1176&2683】Mokia&简单题 CDQ分治

    1176: [Balkan2007]Mokia Time Limit: 30 Sec  Memory Limit: 162 MBSubmit: 1854  Solved: 821[Submit][St ...

  7. Bzoj4066 简单题

    Time Limit: 50 Sec  Memory Limit: 20 MBSubmit: 2185  Solved: 581 Description 你有一个N*N的棋盘,每个格子内有一个整数,初 ...

  8. Bzoj2683 简单题

    Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 1071  Solved: 428 Description 你有一个N*N的棋盘,每个格子内有一个整数, ...

  9. 这样leetcode简单题都更完了

    这样leetcode简单题都更完了,作为水题王的我开始要更新leetcode中等题和难题了,有些挖了很久的坑也将在在这个阶段一一揭晓,接下来的算法性更强,我就要开始分专题更新题目,而不是再以我的A题顺 ...

随机推荐

  1. Linux 运行升讯威在线客服系统:同时支持 SQL Server 和 MySQL 的实现方法

    前段时间我发表了一系列文章,开始介绍基于 .net core 的在线客服系统开发过程. 有很多朋友一直提出希望能够支持 MySQL 数据库,考虑到已经有朋友在用 SQL Server,我在升级的过程中 ...

  2. C#项目中常见的目录和文件

    本文迁移自Panda666原博客,原发布时间:2021年4月17日. Bin 目录 bin是英文binary的缩写, 字面意思是二进制,意指用来存放编译后的结果.C#/VB编译器编译后的程序二进制文件 ...

  3. 适配抖音!三角面转换和3d模型体量减小,轻量化一键即可完成!

    抖音3d特效,可谓是越来越火爆了,这个有着迪士尼画风的3D大眼,就刷屏了国内外用户的首页! 有人好奇这些特效究竟是怎么制作的?其实就是把3D模型调整适配到头部模型上,调整位置或者大小就可以制作出一个简 ...

  4. Tomcat部署接口环境遇到的问题,有没有人能帮忙解决指导一下

    1.在虚拟机中用Tomcat部署一个接口环境:linux+jdk+Tomcat 前提条件:代码包啥的别人都用过,可以部署成功 2.具体部署: a. 利用xftp把所有的代码包war包传送到tomcat ...

  5. BUUCTF-easycap

    easycap 看这个题目应该是流量包来的,wireshark打开即可.没什么特征,直接打开第一个包发现flag

  6. RPA应用场景-日终清算操作

    场景概述 日终清算操作 所涉系统名称 登记过户管理系统(TA),投资交易系统(032) 人工操作(时间/次) 60-80分钟 所涉人工数量 2 操作频率 每日 场景流程 这两个流程一般在晚上8-9点开 ...

  7. 【Java面试】什么是 ISR,为什么需要引入 ISR

    Hi,大家好,我是Mic. 一个工作5年的粉丝,在简历上写精通Kafka. 结果在面试的时候直接打脸. 面试官问他:"什么是ISR,为什么需要设计ISR" 然后他一脸懵逼的看着面试 ...

  8. this关键字、static关键字、方法的调用

    1.带有static关键字的方法,不可使用this关键字.因为其调用方法为类名.方法名(建议这种方式,调用不需要对象的参与),不存在对象. 2.实例方法调用必须有对象的存在,先创建对象,通过引用.的方 ...

  9. 2019 CSP-S 初赛解析

    因为我不会设置用博客园显示Markdown语法,所以在洛谷也写了一份:传送门 一起讨论的这套卷.题干 然后还有一些可以借鉴一下的解析 选择: T1. 注意运算顺序: a%3=1 --> (int ...

  10. squareline搭档OneOS图形组件之可视化GUI开发

    LVGL+OneOS! LVGL,一款很火的GUI开发库,一个高度可裁剪.低资源占用.界面美观且易用的嵌入式系统图形库.本身并不依赖特定的硬件平台,任何满足LVGL硬件配置要求的微控制器均可运行LVG ...