(以上题目出自_rqy两年前)

#A:桶哥的问题——买桶【链接】

【题目描述】

桶哥要买一些全家桶。他有a元钱,而每个桶要花b元钱。他能不能买到c个桶?

【输入格式】

一行三个整数a, b, c

【输出格式】

Yes或No

【输入样例#1】                    【输出样例#1】

26 4 5                                    Yes

【输入样例#2】                    【输出样例#2】

3 4 5                                        No


显然这道题很很很简单的了,然后数据好像也没有需要特判的(好像有些人特判然后就90pts了qwq)

思路就是直接b*c与a比,如果b*c≤a,那么Yes,否则No

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath> using namespace std; long long a,b,c;//唯一注意要开long long int main(){
scanf("%lld%lld%lld",&a,&b,&c);
long long ans = b*c;
if(ans<=a)cout<<"Yes"<<endl;
else cout<<"No"<<endl;
return ;
}

没什么大问题,next~


#B:桶哥的问题——送桶【链接】

【题目描述】

桶哥买了n个桶,他要将这些桶送去n个人的家。他送第i个桶需要ai的时间,需要在bi之前送到。桶哥很懒,他想要尽量晚起身去送桶。问他最晚什么时候要去送桶?

桶哥在送完一个桶之后可以紧接着去送另一个桶。

【输入格式】

一行一个整数n,以下n行每行两个整数表示ai,bi。

【输出格式】

一行一个整数,表示桶哥最晚什么时候起身。

【输入样例】                              【输出样例】

4                                                    2
1 6
2 7
2 8
1 7


40pts-错误思路:把所有ai加起来sum(ai),然后找到一个最大的bi,用bi(max)-sum(ai)可以得40pts;

90pts-错误思路:计算每个ai与bi的差值,以及bi(max)-sum(ai),取min,可以骗到90pts;

100pts-正确思路:
对所有的桶按照bi的大小,从小到大排序(对于ai没有要求)(可以用sort解决),然后从1~n for循环:求出当前枚举到的所有ai的和suma,用当前的bi(因为已经排过序了所以当前bi即为当前最大的bi)减去suma(差值暂且叫它kb),取最小的kb即为ans;

90pts代码:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
const int maxn=1e6+; using namespace std; int n,minn=1e9+,suma,maxb; struct tong{
int a,b,c;
}t[maxn]; bool cmp(tong x,tong y){
if(x.b==y.b)return x.a>y.a;
else return x.b<y.b;
} int main(){
scanf("%d",&n);
for(int i=;i<=n;i++){
scanf("%d%d",&t[i].a,&t[i].b);
t[i].c=t[i].b-t[i].a;
if(t[i].c<minn) minn = t[i].c;
if(t[i].b>maxb)maxb=t[i].b;
suma+=t[i].a;
}
int sumc=maxb-suma;
if(sumc<minn)cout<<sumc<<endl;
else cout<<minn<<endl; return ;
}

100pts代码:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
const int maxn=1e6+; using namespace std; int n,suma,kb,ans=1e9; struct tong{
int a,b,c;
}t[maxn]; bool cmp(tong x,tong y){
if(x.b==y.b)return x.a>y.a;
else return x.b<y.b;
} int main(){ scanf("%d",&n);
for(int i=;i<=n;i++)
scanf("%d%d",&t[i].a,&t[i].b); sort(t+,t+n+,cmp); for(int i=;i<=n;i++){
suma+=t[i].a;
kb=t[i].b-suma;
if(kb<ans) ans=kb;
} cout<<ans<<endl; return ;
}

#C:桶哥的问题——吃桶【链接】

【题目描述】

桶哥的桶没有送完,他还有n个桶。他决定把这些桶吃掉。他的每一个桶两个属性:种类ai和美味值bi。若下标为x,y,z(下标从1开始)的三个桶满足:

x<z且x+y=z-2y且ax=az

那么它们构成一个套餐,会产生

(x+z)*(bx-bz

的价值。问:一共会产生多少价值?

【输入格式】

第一行两个整数n,m,表示共有m种共n个桶。

第二行n个整数表示bi,

第三行n个整数表示ai。

【输出格式】

一行一个整数,表示一共会产生多少价值。由于这个数可能很大,你只需要输出它除以10007的余数。如果答案是负的,请将其加上10007再对10007取余。

【输入样例#1】                【输出样例#1】

5 2                                       23
6 7 8 7 3
1 2 2 1 2

【输入样例#2】                 【输入样例#2】

5 2                                        9974
6 3 8 7 7
1 2 2 1 2

【数据范围】(是个谜)


40~50pts思路:

直接暴力模拟这个过程,时间复杂度大概是O(n)的

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
const int maxn=;
const int mo=; using namespace std; int n,m,xb,ans; struct jgt{
int a,b,xb;
}t[maxn]; int main(){
scanf("%d%d",&n,&m); for(int i=;i<=n;i++)
scanf("%d",&t[i].b); for(int i=;i<=n;i++)
scanf("%d",&t[i].a); for(int i=;i<=n;i++){
for(int j=;j<=n;j++){
xb=i+j*;
if(t[xb].a==t[i].a) ans += ((i+xb)%mo*(t[i].b-t[xb].b)%mo)%mo;
else continue;
}
}
ans%=mo;ans+=mo;ans%=mo;
cout<<ans<<endl;
}

100pts:

化简介个式子,可以知道x与z mod3 同余。那么我们可以不管y了,将这n个桶分为下标mod3余1,mod3余2和mod3余0三种,那么对于组来说:

这个式子可以拆成xbx+zbx-xbz-zbz

对于每一项分开枚举:

xbx:

开两个数组:c1[]和c[],c1[i]用来储存第i种桶的xbx是多少,c[i]用来储存当前枚举到的所有的第i种桶的xbx的和(每个xbx只加一遍)

那么有:

        c1[t[i].a] = (c1[t[i].a]%mod+c[t[i].a]%mod);//存储xbx
//举个例子:假设mod3余1的有:(下标,种类,价值)(1,1,6)(4,1,7)(7,1,2),
那么第一遍:c1[1]=0+0=0;c[1]=0+1*6=6第二遍:
c1[]=+=;c[]=+*=;第三遍:c1[]=+;c[]=+;
这样刚好每个x都加了对应的遍数
c[t[i].a] = (c[t[i].a]%mod+(i%mod)*(t[i].b%mod))%mod; //用来存储xbx的一遍和。另外要注意把c1放在前面而不是c。

zbx:

开两个数组:c2[]和c0[],c2[i]用来储存第i种桶的zbx是多少,c0[i]用来储存当前枚举到的所有的第i种桶的bx和;

(啊我的天不知道怎么表达qwq)

    c2[t[i].a] = (c2[t[i].a]%mod+(i%mod)*(c0[t[i].a])%mod)%mod;//储存zbx
c0[t[i].a] = (c0[t[i].a]%mod+t[i].b)%mod;//用于计算zbx时,储存bx

xbz:

开两个数组:c4[]和c3[],c4[i]用来储存第i种桶的xbz是多少,c3[i]用来储存当前枚举到的所有的第i种桶的下标和;

    c4[t[i].a] = (c4[t[i].a]%mod+c3[t[i].a]%mod*t[i].b%mod)%mod;//存储xbz
c3[t[i].a] = c3[t[i].a]%mod+i%mod;//存储下标的和,用于计算xbz

zbz:

开两个数组:c6[]和c5[],c6[i]用来储存第i种桶的zbz是多少,c5[i]用来储存当前枚举到的所有的第i种桶的个数;

  c6[t[i].a] = (c6[t[i].a]%mod+t[i].b%mod*c5[t[i].a]%mod*i%mod)%mod;//储存zbz
c5[t[i].a] ++;//记录第i种桶个数

嗯-大概吧:

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring> using namespace std; int read() {
int ans = , c, f = ;
while (!isdigit(c = getchar()))
if (c == '-') f *= -;
do ans = ans * + c - '';
while (isdigit(c = getchar()));
return ans * f;
} const int mod=;
const int maxn=;
int n,m,ans,ans1;
int c[maxn>>], c1[maxn>>], c2[maxn>>], c3[maxn>>],c0[maxn>>],c4[maxn>>];
int c5[maxn>>],c6[maxn>>];
struct jgt{
int a,b;
}t[maxn]; int main(){ scanf("%d%d",&n,&m); for(int i=;i<=n;i++)
scanf("%d",&t[i].b),t[i].b%=mod; for(int i=;i<=n;i++)
scanf("%d",&t[i].a); for(int i=;i<=n;i+=){
c1[t[i].a] = (c1[t[i].a]%mod+c[t[i].a]%mod);//存储xbx
c[t[i].a] = (c[t[i].a]%mod+(i%mod)*(t[i].b%mod))%mod;//用来存储xbx的一遍和
c2[t[i].a] = (c2[t[i].a]%mod+(i%mod)*(c0[t[i].a])%mod)%mod;//储存zbx
c0[t[i].a] = (c0[t[i].a]%mod+t[i].b)%mod;//用于计算zbx时,储存bx
c4[t[i].a] = (c4[t[i].a]%mod+c3[t[i].a]%mod*t[i].b%mod)%mod;//存储xbz
c3[t[i].a] = c3[t[i].a]%mod+i%mod;//存储下标的和,用于计算xbz
c6[t[i].a] = (c6[t[i].a]%mod+t[i].b%mod*c5[t[i].a]%mod*i%mod)%mod;
c5[t[i].a] ++;
} for(int i=;i<=m;i++)
ans = (ans%mod+c1[i]%mod+c2[i]%mod-c4[i]-c6[i])%mod; memset(c, , sizeof(c));memset(c0, , sizeof(c0));
memset(c1, , sizeof(c1));memset(c2, , sizeof(c2));
memset(c4, , sizeof(c4));memset(c3, , sizeof(c3));
memset(c5, , sizeof(c5));memset(c6, , sizeof(c6)); for(int i=;i<=n;i+=){
c1[t[i].a] = (c1[t[i].a]%mod+c[t[i].a]%mod);//存储xbx
c[t[i].a] = (c[t[i].a]%mod+(i%mod)*(t[i].b%mod))%mod;//用来存储xbx的一遍和
c2[t[i].a] = (c2[t[i].a]%mod+(i%mod)*(c0[t[i].a])%mod)%mod;//储存zbx
c0[t[i].a] = (c0[t[i].a]%mod+t[i].b)%mod;//用于计算zbx时,储存bx
c4[t[i].a] = (c4[t[i].a]%mod+c3[t[i].a]%mod*t[i].b%mod)%mod;//存储xbz
c3[t[i].a] = c3[t[i].a]%mod+i%mod;//存储下标的和,用于计算xbz
c6[t[i].a] = (c6[t[i].a]%mod+t[i].b%mod*c5[t[i].a]%mod*i%mod)%mod;
c5[t[i].a] ++;
} for(int i=;i<=m;i++)
ans = (ans%mod+c1[i]%mod+c2[i]%mod-c4[i]-c6[i])%mod; memset(c, , sizeof(c));memset(c0, , sizeof(c0));
memset(c1, , sizeof(c1));memset(c2, , sizeof(c2));
memset(c4, , sizeof(c4));memset(c3, , sizeof(c3));
memset(c5, , sizeof(c5));memset(c6, , sizeof(c6)); for(int i=;i<=n;i+=){
c1[t[i].a] = (c1[t[i].a]%mod+c[t[i].a]%mod);//存储xbx
c[t[i].a] = (c[t[i].a]%mod+(i%mod)*(t[i].b%mod))%mod;//用来存储xbx的一遍和
c2[t[i].a] = (c2[t[i].a]%mod+(i%mod)*(c0[t[i].a])%mod)%mod;//储存zbx
c0[t[i].a] = (c0[t[i].a]%mod+t[i].b)%mod;//用于计算zbx时,储存bx
c4[t[i].a] = (c4[t[i].a]%mod+c3[t[i].a]%mod*t[i].b%mod)%mod;//存储xbz
c3[t[i].a] = c3[t[i].a]%mod+i%mod;//存储下标的和,用于计算xbz
c6[t[i].a] = (c6[t[i].a]%mod+t[i].b%mod*c5[t[i].a]%mod*i%mod)%mod;
c5[t[i].a] ++;
} for(int i=;i<=m;i++)
ans = (ans%mod+c1[i]%mod+c2[i]%mod-c4[i]-c6[i])%mod; printf("%d",(ans+mod)%mod); }

最后,一定要记得:多取模

败在了取mod取得少上qwq

end-

【校内test】桶哥的问题的更多相关文章

  1. 校内题目T2691 桶哥的问题——送桶

    这是一道校内题目,但迷路的蒟蒻们同样被欢迎来此学习QWQ 题目描述: 题目背景 @桶哥本校——皎月pks大佬OrzOrz 买完了桶,桶哥要去送桶. 题目描述 桶哥买了nn个桶, 他要将这些桶送去nn个 ...

  2. 校内题目T2695 桶哥的问题——吃桶

    同T2一样外校蒟蒻可能没看过: 题目描述: 题目背景 @桶哥 桶哥的桶没有送完. 题目描述 桶哥的桶没有送完,他还有n个桶.他决定把这些桶吃掉.他的每一个桶两个属性:种类aia_iai​和美味值bib ...

  3. T2695 桶哥的问题——吃桶

    ~~~~~我~是~真的~忍不了~这个~取模~的~锅~了~~~~~ T2695 桶哥的问题——吃桶 前传 1.T2686 桶哥的问题——买桶 这题真的hin简单,真的 2.T2691 桶哥的问题——送桶 ...

  4. 【洛谷T2695 桶哥的问题——吃桶】

    这是我们团队的一个题目(就是一个_rqy说很好写的题QwQ) 题目背景 @桶哥 这个题目的思路很玄学(性感_rqy在线讲解) 60 Pts 对于前面的六十分,好像很好拿,单纯的打一个模拟 唯一需要注意 ...

  5. 【桶哥的问题——吃桶-简化版】【洛谷p2671】求和

    求和=>[链接] 题目相较起_rqy出的要简单很多,来自noip普及组2015 化简这个式子:x+z=2y,故x与z mod 2同余,因此和桶哥的问题——吃桶一样的思路就可以做出来啦qwq: # ...

  6. T2695 桶哥的问题——吃桶 题解

    校内测试 ------T3 对于这个题,首先想到的应该就是暴力枚举了吧,看看数据范围,60就是白送的啦!(但是我也不知道怎么才20分qwq) 思路分析: 这个题要你求所有套餐的总价值,先看一眼产生套餐 ...

  7. T2695 桶哥的问题——送桶 题解

    校内测试 ------T2 看完这个题,就觉得和贪心那一块的任务调度很像,于是思路就是贪心啦! 蒟蒻的我,也就只能想到用贪心了,但是不知道怎么用qwq 这是我考试当时的思路,数据水骗了80分qwq: ...

  8. 听桶哥讲session和cookie

    首先,cookie和session是什么关系? 他们的关系很简单,利用和被利用的关系. 话说,由于http协议的无状态特性,同一client两个不同的请求之间完全独立,没有很好的办法进行一些数据共享, ...

  9. T2691 桶哥的问题——送桶

    这个题其实不难,就是按照结束时候的顺序从大到小走一遍,能送的就送,如果区间不重合就更新一下 代码: #include<iostream> #include<cstdio> #i ...

随机推荐

  1. MHA配置

    1,背景 MHA的目的在于维持MySQL Replication中Master库的高可用性,其最大特点是可以修复多个Slave之间的差异日志,最终使所有Slave保持数据一致,然后从中选择一个充当新的 ...

  2. #415 Div2 Problem C Do you want a data? (math && 前后缀和 && 快速幂)

    题意: 首先定义集合的F值为  这个集合里面最大值和最小值的差. 现给出一个拥有n个数的集合(没有相同的元素), 要求求出这个集合内所有子集的F的值的和.例如: {4.7}这个集合里面有子集{4}.{ ...

  3. mysql 将时间戳与日期时间的转换

    from_unixtime()是MySQL里的时间函数 mysql>SELECT FROM_UNIXTIME( 1249488000, '%Y%m%d' )  ->20071120 mys ...

  4. Java中for each与正常for循环效率对比

    循环ArrayList时,普通for循环比foreach循环花费的时间要少一点:循环LinkList时,普通for循环比foreach循环花费的时间要多很多. 当我将循环次数提升到一百万次的时候,循环 ...

  5. EventChannel 原生向Flutter传递数据

    目的:原生页面主动向Flutter页面传递信息 1 flutter步骤 定义EventChannel static const EventChannel eventChannel = EventCha ...

  6. golang 通过reflect反射修改值

    不是所有的反射值都可以修改.对于一个反射值是否可以修改,可以通过CanSet()进行检查. 要修改值,必须满足: 可以寻址 可寻址的类型: 指针指向的具体元素 slice的元素 可寻址的结构体的字段( ...

  7. ShuffleNet: An Extremely Efficient Convolutional Neural Network for Mobile Devices

    1. 摘要 作者介绍了一种计算非常高效的 CNN 结构称之为 ShuffleNet,它是专门为计算资源非常有限的移动设备设计的. 这种新的结构主要用到了两种操作:分组点卷积(pointwise gro ...

  8. 【7】解决:移动端点击a链接出现蓝色边框

    [1]_blank : 浏览器总在一个新打开.未命名的窗口中载入目标文档. [2]title :  鼠标悬浮显示的文字. [3]href : 跳转到哪个链接.     a{    border: no ...

  9. C#连接Oracle数据库的四种方法

    C#连接数据库的四种方法 在进行以下连接数据库之前,请先在本地安装好Oracle Client,同时本次测试System.Data的版本为:2.0.0.0. 在安装Oracle Client上请注意, ...

  10. Tensorflow Lite tflite模型的生成与导入

    假如想要在ARM板上用tensorflow lite,那么意味着必须要把PC上的模型生成tflite文件,然后在ARM上导入这个tflite文件,通过解析这个文件来进行计算. 根据前面所说,tenso ...