同T2一样外校蒟蒻可能没看过:

题目描述:

题目背景

@桶哥

桶哥的桶没有送完。

题目描述

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

x<z x < z x<z 且 x+y=z−2y x + y = z - 2y x+y=z−2y 且 ax=az a_x = a_z ax​=az​

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

(x+z)∗(bx−bz) (x + z) * (b_x - b_z) (x+z)∗(bx​−bz​)

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

上面那个看不清楚的下标是z

输入输出格式

输入格式:

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

第二行n个整数表示bib_ibi​,

第三行n个整数表示aia_iai​,(下标)

输出格式:

一行一个整数,表示一共会产生多少价值。由于这个数可能很大,你只需要输出它除以10007的余数。

如果答案是负的,请将其加上10007再对10007取余。如-1应输出10006.


正解开始:

然而_rqy大佬讲的我并没怎么听懂,所以也是一蒙一蒙的。

转换一下公式:

x+y=z-2y
z-x=3y
x,z种类相等

那么把求价值公式:

展开得:xbx+zbx-xbz-zbz(注意下标),

也就是说,这个东西和y半毛钱关系都没有!

理一下关系:

1,z>x

2.z-x为3的倍数

3.z和x为同一种类的桶

那么考虑思路:同余枚举

一个数%3无非是余1余2余3(余0)

那么从1,2,3开始,按下标网上枚举,分3种,分别对应3个不同外循环,而内循环就是网上枚举到最后一个下标,那么别看是双重循环,但是你把枚举次数加起来,是O(n)的。

直接快了好多QWQ

那么回归正题:

内层循环干什么?

当然是利用∑来求和了

安利核心公式:

(x+z)*(bx-bz)=∑x*bx+z*∑bx-bz*∑x-z*bz*∑1

为什么∑的地方不同呢???

因为我们要对z枚举(或者x也行),这样把上一层求和的就给保存下来继续用而不是再for循环求一遍

其实用双层循环而不是三重循环来求阶乘也是一个道理

因为z<x,也就是说对于每一个z,前面从0到z-3的x都满足,都要被加进∑内部

每次只加一个而不是又来一遍for循环。。。

这个比较清楚了吧。。。。。。

上代码了。。。QWQ

#include <algorithm>
#include <cctype>
#include <cstdio>
#include <cstring> int readInt() {//快读
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 = ;//定义%数组 int b[], a[];
int S[], Sx[], Sbx[], Sxbx[];//s为∑ int main() {
int n = readInt(); /* m = */readInt();
for(int i = ; i <= n; i++) b[i] = readInt() % mod;
for(int i = ; i <= n; i++) a[i] = readInt();
int ans = ;
for (int cc = ; cc <= ; ++cc) {
// { cc, cc+3, cc+6 ... } 分一组
memset(S, , sizeof(S));
memset(Sx, , sizeof(Sx));
memset(Sbx, , sizeof(Sbx));
memset(Sxbx, , sizeof(Sxbx));
for(int i = cc; i <= n; i += ) {
ans = (ans + i % mod * Sbx[a[i]] % mod) % mod;
ans = (ans - b[i] * Sx[a[i]] % mod) % mod;
ans = (ans + Sxbx[a[i]]) % mod;
ans = (ans - S[a[i]] * b[i] % mod * (i % mod) % mod) % mod;
S[a[i]] = (S[a[i]] + ) % mod;
Sx[a[i]] = (Sx[a[i]] + i) % mod;
Sbx[a[i]] = (Sbx[a[i]] + b[i]) % mod;
Sxbx[a[i]] = (Sxbx[a[i]] + i % mod * b[i] % mod) % mod;
}
}
printf("%d", (ans + mod) % mod);
return ;
}

气喘吁吁的甩胳膊,,

%_rqy大佬,是他出的题和给我们讲的题!

校内题目T2695 桶哥的问题——吃桶的更多相关文章

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

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

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

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

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

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

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

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

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

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

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

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

  7. 洛谷 T2691 桶哥的问题——送桶

    嗯... 题目链接:https://www.luogu.org/problem/T2691 这道题有一点贪心的思想吧...并且思路与题目是倒着来的(貌似这种思路已经很常见的... 先举个栗子: 引出思 ...

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

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

  9. 【校内test】桶哥的问题

    (以上题目出自_rqy两年前) #A:桶哥的问题——买桶[链接] [题目描述] 桶哥要买一些全家桶.他有a元钱,而每个桶要花b元钱.他能不能买到c个桶? [输入格式] 一行三个整数a, b, c [输 ...

随机推荐

  1. Activity的onSaveinstaceState()保存fragment状态

    Activity的onCreat方法: @Override protected void onCreate(Bundle savedInstanceState) { FragmentManager s ...

  2. Jmeter(九)集合点

    性能测试需要模拟大量用户并发,集合点能够尽量让虚拟用户同一时刻发送请求, 在Jmeter中集合点是通过定时器-同步定时器来完成的.

  3. 【转】Unity ZTest 深度测试 & ZWrite 深度写入

    原文连接:https://www.cnblogs.com/ljx12138/p/5341381.html 参考另一篇写的比较好的:Unity Shader中的 ZTest & ZWrite 初 ...

  4. 使程序在Linux下后台运行,程序运行前后台切换

    一.为什么要使程序在后台执行 我们计算的程序都是周期很长的,通常要几个小时甚至一个星期.我们用的环境是用putty远程连接到日本Linux服务器.所以使程序在后台跑有以下三个好处: 1:我们这边是否关 ...

  5. RAC FAILover详解(转载)

    Oracle  RAC 同时具备HA(High Availiablity) 和LB(LoadBalance). 而其高可用性的基础就是Failover(故障转移). 它指集群中任何一个节点的故障都不会 ...

  6. Go语言mgo使用情况

    文重点介绍mgo使用,仅简单介绍mongodb. mongodb特性   mongdb简单介绍 注意: 上图已经告知我们mongo不支持事务,在开发项目应用时,想要保证数据的完整性请考虑关系型数据库( ...

  7. C++中sort函数使用方法

    一.sort函数 1.sort函数包含在头文件为#include<algorithm>的c++标准库中,调用标准库里的排序方法可以实现对数据的排序,但是sort函数是如何实现的,我们不用考 ...

  8. Unity 动画属性

    在动画的使用上使用不当的设置往往会造成不可预料的结果. 首先,如果动画自身可以驱动物体移动,那么在Animator组件上必须选择apply root motion,物体的动画位移才能生效,否则动画只能 ...

  9. BeautifulSoup解析豆瓣即将上映的电影信息

    工欲善其事,必先利其器,我们首先得了解beautifulsoup的使用,这其实是一个比较简单的东西   BeautifulSoup的基本使用语法规则 .find() 使用示例 soup.find('a ...

  10. 【数字图像处理】Bilateral Filters

    [数字图像处理]Bilateral Filters https://www.yuque.com/lart/idh721/bf 简单介绍 双边滤波是一种非线性的可以模糊图像并且能保留一定的边缘信息的技术 ...