CF1478A - Nezzar and Colorful Ball(数学)

CF1478A - Nezzar and Colorful Balls

Solution

真不戳,这AAA题真不戳,我直接好家伙。

讲一下我搞了半个小时的垃圾做法 (好吧后来看了看标算好像和我是一样的)
大概是容易发现你两个数(x,y)(x,y)(x,y)做来做去最后一定是ax−(a−1)yax-(a-1)yax(a1)y的形式,然后再继续搞一搞三个数的,最后你发现每个数的贡献次数之和等于111,于是问题变成了这样子:
给定a1...ana_1...a_na1...an,问是否存在一个x1...xnx_1...x_nx1...xn,使得:
∑i=1nxi=1∑i=1naixi=k\sum_{i=1}^n x_i=1\\ \sum_{i=1}^n a_ix_i=k i=1nxi=1i=1naixi=k
从上面的式子可知:
xn=1−∑i=1n−1xix_n=1-\sum_{i=1}^{n-1} x_i xn=1i=1n1xi
代入下面的式子:
∑i=1naixi=∑i=1n−1aixi+an(1−∑i=1n−1xi)=∑i=1n−1(ai−an)xi+an\sum_{i=1}^na_ix_i=\sum_{i=1}^{n-1}a_ix_i+a_n(1-\sum_{i=1}^{n-1}x_i)=\sum_{i=1}^{n-1}(a_i-a_n)x_i+a_n i=1naixi=i=1n1aixi+an(1i=1n1xi)=i=1n1(aian)xi+an
于是我们有:
∑i=1n−1(ai−an)xi=k−an\sum_{i=1}^{n-1}(a_i-a_n)x_i=k-a_n i=1n1(aian)xi=kan
那么就是一个∑iaixi=b\sum_i a_ix_i=biaixi=b的裴蜀定理的形式,有解的条件就是:
gcd(ai−an)∣k−angcd(a_i-a_n)|k-a_n gcd(aian)kan
注意这里为了避免ai−an<0a_i-a_n<0aian<0,我们给降序序列排序,于是ana_nan为最小值。

时间复杂度O(nlgn)O(nlgn)O(nlgn)

然后就没了,对,就没了。我真是个铁憨憨。

Code

#include <vector>
#include <list>
#include <map>
#include <set>
#include <deque>
#include <queue>
#include <stack>
#include <bitset>
#include <algorithm>
#include <functional>
#include <numeric>
#include <utility>
#include <sstream>
#include <iostream>
#include <iomanip>
#include <cstdio>
#include <cmath>
#include <cstdlib>
#include <cctype>
#include <string>
#include <cstring>
#include <ctime>
#include <cassert>
#include <string.h>
//#include <unordered_set>
//#include <unordered_map>
//#include <bits/stdc++.h>#define MP(A,B) make_pair(A,B)
#define PB(A) push_back(A)
#define SIZE(A) ((int)A.size())
#define LEN(A) ((int)A.length())
#define FOR(i,a,b) for(int i=(a);i<(b);++i)
#define fi first
#define se secondusing namespace std;template<typename T>inline bool upmin(T &x,T y) { return y<x?x=y,1:0; }
template<typename T>inline bool upmax(T &x,T y) { return x<y?x=y,1:0; }typedef long long ll;
typedef unsigned long long ull;
typedef long double lod;
typedef pair<int,int> PR;
typedef vector<int> VI;const lod eps=1e-11;
const lod pi=acos(-1);
const int oo=1<<30;
const ll loo=1ll<<62;
const int mods=998244353;
const int MAXN=600005;
const int INF=0x3f3f3f3f;//1061109567
/*--------------------------------------------------------------------*/
inline ll read()
{ll f=1,x=0; char c=getchar();while (c<'0'||c>'9') { if (c=='-') f=-1; c=getchar(); }while (c>='0'&&c<='9') { x=(x<<3)+(x<<1)+(c^48); c=getchar(); }return x*f;
}
ll a[MAXN];
ll gcd(ll x,ll y) { return y==0?x:gcd(y,x%y); }
signed main()
{int Case=read();while (Case--){int n=read(); ll k=read(),g=0;for (int i=1;i<=n;i++) a[i]=read();sort(a+1,a+n+1,greater<ll>());for (int i=1;i<n;i++) a[i]-=a[n]; k-=a[n];for (int i=1;i<n;i++) g=gcd(g,a[i]);puts(k%g==0?"YES":"NO");} return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/315538.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Codeforces Round #693 (Div. 3) E. Correct Placement 思维

传送门 题意&#xff1a; 思路&#xff1a; 对于每个人都有个二元组(x,y)(x,y)(x,y)&#xff0c;从题意中提取有效信息就是&#xff1a;当(x1,y1)(x_1,y_1)(x1​,y1​)的最大值大于(x2,y2)(x_2,y_2)(x2​,y2​)的最大值&#xff0c;(x1,y1)(x_1,y_1)(x1​,y1​)的最小值大于(…

记录一次生产发布事件——(简单的非空验证也能引发大问题)

事件经过下午四点&#xff0c;发布生产g环境(生产环境m为正式环境&#xff0c;g为内测环境)。这时测试有人提出“服务器忙”。听到这里我赶紧翻了翻内测日志&#xff0c;发现了最熟悉的老朋友——未将对象引用设置到对象的实例。问题出现在如下代码上。(我下面附上了伪代码&…

Codeforces Round #705 (Div. 2) D. GCD of an Array 质因子分解 + stl维护

传送门 题意&#xff1a; 给nnn个数&#xff0c;让后qqq个操作&#xff0c;每次选择一个位置的数使其乘xxx&#xff0c;每次询问后输出所有数的gcdgcdgcd。 思路&#xff1a; 这个题思路算是比较好想的。首先就是一个计算方式即计算所有数的gcdgcdgcd&#xff0c;这个比较容易…

CF938G Shortest Path Queries(线性基,线段树分治,并查集)

CF938G Shortest Path Queries Solution 套路题。 xorxorxor最短路可以用线性基维护&#xff08;把每个环的边权异或和放进线性基&#xff0c;询问时把树边路径边权异或和放在线性基里跑出最小值即可&#xff09;。 然后因为线性基删除比较慢而麻烦&#xff08;注意线性基是…

程序员过关斩将--你为什么还在用存储过程?

点击上面“蓝字”关注&#xff0c;带你看好电影菜菜哥&#xff0c;我新接手了一个项目&#xff0c;看的我头疼呀业务有这么复杂呀&#xff1f;不是的&#xff0c;这个老项目完全是用存储过程写的&#xff0c;每个存储过程都好几百行这样呀&#xff0c;是够头疼的~有没有办法帮我…

Educational Codeforces Round 101 (Rated for Div. 2) C. Building a Fence 思维取范围

传送门 题意&#xff1a; 思路&#xff1a; 刚看到这个题其实是没什么思路&#xff0c;想过从前往后推或者从后往前推&#xff0c;但是都不是很可行。因为两边都有一个固定的挡板挡住&#xff0c;我们可以根据其中的一个算出来每个位置高度的范围&#xff0c;让后检查一下范…

CF1237F Balanced Domino Placements(组合计数,dp)

CF1237F Balanced Domino Placements Solution 显然可以先考虑横着的骨牌&#xff0c;再考虑竖着的骨牌。但是思路卡在了选取横着的骨牌会对竖着的骨牌的相邻对数产生影响。 然而事实上我们只需要换一个统计顺序&#xff0c;先考虑横着的骨牌的列和竖着的骨牌的行&#xff0…

asp.net core 集成JWT

【什么是JWT】JSON Web Token&#xff08;JWT&#xff09;是目前最流行的跨域身份验证解决方案。JWT的官网地址&#xff1a;https://jwt.io/通俗地来讲&#xff0c;JWT是能代表用户身份的令牌&#xff0c;可以使用JWT令牌在api接口中校验用户的身份以确认用户是否有访问api的权…

2021年度训练联盟热身训练赛第一场 E Early Orders 思维 + 栈

传送门 题意&#xff1a; 给nnn个数&#xff0c;一个kkk&#xff0c;求aaa中包含1−k1-k1−k且字典序最小的子序列。 思路1&#xff1a; 记p[i]p[i]p[i]为iii出现的最后位置&#xff0c;让后维护一个栈&#xff0c;当这个数不在栈里时将其入栈&#xff0c;入栈的时候跟栈顶比…

CF855G. Harry Vs Voldemort(边双,并查集,dp)

CF855G. Harry Vs Voldemort Solution 考虑每增加一条边都会把路径上的边双都连成一个大边双&#xff0c;考虑合并xxx和yfaxy fa_xyfax​ 这两个边双的贡献&#xff0c;分类讨论&#xff1a; 选取三个同边双内的点。选取在同一个边双内选两个点&#xff0c;剩下一个在其他边…

xBIM(eXtensible Building Information Modelling)可扩展的建筑信息模型

一、xBIM 简介BIM&#xff08;Building Information Modelling&#xff09;建筑信息模型&#xff0c;xBIM&#xff08;eXtensible Building Information Modelling&#xff09;可扩展的建筑信息模型。它是一个.NET 开源软件开发BIM工具包&#xff0c;支持BuildingSmart数据模型…

Codeforces Global Round 12 C1 C2. Errich-Tac-Toe 思维构造 好题

传送门 题意&#xff1a; 给了如下规则&#xff0c;上面三个只要出现一个情况就是非平局&#xff0c;现在给你个字符矩阵&#xff0c;让后其中XXX字符有KKK个(hardhardhard版本XXX和OOO一共KKK个)&#xff0c;每次操作可以将XXX变成OOO&#xff0c;OOO变成XXX&#xff0c;用不…

AGC019D - Shift and Flip(枚举)

AGC019D - Shift and Flip 很久之前WAWAWA的题&#xff0c;终于补掉了。。。这题细节是真的烦。 Solution 这题数据范围较小&#xff0c;于是我们枚举最终AAA与BBB的哪一个字符开始匹配&#xff0c;设这个位置为SSS。 然后考虑分顺时针/逆时针转到SSS两种情况讨论。 以逆时…

译 | .NET Core 3.0 Preview 6 已发布

原文&#xff1a;Richard Lander翻译&#xff1a;Edi Wang今天&#xff0c;我们宣布 .NET Core 3.0 Preview 6。它的更新包括编译程序集以改进启动、使用链接器和 EventPipe 改进优化应用程序的大小。我们还在 ARM64 上发布了针对 Alpine 的新 Docker 镜像。立即在 Windows、ma…

Codeforces Global Round 12 D. Rating Compression 思维 + 贪心

传送门 题意&#xff1a; 给一个长度为nnn的数组aaa&#xff0c;定义一个数组bbb&#xff0c;且bjminj<i<jk−1aib_jmin_{j<i<jk-1}a_ibj​minj<i<jk−1​ai​&#xff0c;比如j3j3j3的时候&#xff0c;a[1,3,4,5,2]a[1,3,4,5,2]a[1,3,4,5,2]&#xff0c;b3…

CF528C. Data Center Drama(欧拉回路,构造)

CF528C. Data Center Drama Solution 容易发现&#xff0c;加边后的图必然满足所有点的度为偶数&#xff0c;并且总的边数是偶数&#xff0c;这启发我们使用欧拉回路。 设欧拉回路为vk1et1vk2et2vk3...vk∣E∣1v_{k_1}e_{t_1}v_{k_2}e_{t_2}v_{k_3}...v_{k_{|E|1}}vk1​​et…

庆祝.NET Core悄然崛起:免费送50本优秀技术书籍,请笑纳!!

为了庆祝 .NET社区蓬勃发展&#xff0c;今天特地联合几位.NET大佬给大家带来50本高质量技术书籍。.NET Core自开源以来&#xff0c;依托微软强大的科技实力日趋完善&#xff0c;再也不是10年前那种封闭状态。强大的跨平台&#xff0c;强大的IDE&#xff0c;强大的语言特性&…

P2371 [国家集训队]墨墨的等式 同余最短路

传送门 题意&#xff1a; 思路&#xff1a; 一个同于最短路的板子题&#xff0c;初始的时候值为0&#xff0c;所以设dis[0]0dis[0]0dis[0]0&#xff0c;让后选择一个最小的a[i]a[i]a[i]作为basebasebase&#xff0c;跑一遍同余最短路就好啦。跑完dis[i]dis[i]dis[i]表示在模b…

CF997E. Good Subsegments(线段树,单调栈)

CF997E. Good Subsegments Description 给定一个序列&#xff0c;多次询问一个区间内的连续段个数。 n,q≤2105n,q \leq 2\times 10^{5}n,q≤2105 Solution 算得上是经典题了吧。 Part one 先考虑求全部的连续段个数。 相当于求区间内mx−mn1−len0mx - mn 1 - len 0m…

ASP.NET Core WebAPI帮助页--Swagger简单使用1.0

1、什么是Swagger&#xff1f;Swagger是一个规范且完整的框架&#xff0c;提供描述、生产、消费和可视化RESTful API&#xff0c;它是为了解决Web API生成有用文档和帮助页的问题。2、为啥选用swagger?1&#xff09;它具有交互式文档、客户端SDK生成和API可发现性等优点。2&am…