数学 赛码 1010 GCD
/*
数学:官方题解
首先,数组中每个元素至少是1
然后对于任意一个询问Li, Ri, Ansi, 说明Li ~ Ri中的元素必定是Ansi的倍数,那么只需将其与Ansi取最小公倍数即可
如果在计算过程中有一个值超出了可行范围,那么就无解了
在计算完成之后,注意这个解并不一定是正确的,还需要对于所有询问检查一遍
时间复杂度O(NQlogX), X为值的范围
题目不难,算是签到题,可是队友考虑复杂了,GCD (0, ..) ?!
反思:题目要读仔细,组队时做不来要让队友帮忙读题想题
*/
#include <cstdio>
#include <iostream>
#include <algorithm>
#include <cstring>
#include <string>
#include <map>
#include <vector>
#include <set>
#include <cmath>
#include <queue>
using namespace std; typedef long long LL; const int MAXN = 1e3 + ;
const int INF = 0x3f3f3f3f;
LL a[MAXN];
int l[MAXN], r[MAXN];
LL ans[MAXN]; LL GCD(LL a, LL b)
{
return b ? GCD (b, a % b) : a;
} LL LCM(LL a, LL b)
{
return a / GCD (a, b) * b;
} int main(void) //赛码 1010 GCD
{
//freopen ("J.in", "r", stdin); int t, n, q;
scanf ("%d", &t);
while (t--)
{
scanf ("%d%d", &n, &q);
for (int i=; i<=n; ++i) a[i] = ; bool flag = false;
for (int i=; i<=q; ++i)
{
scanf ("%d%d%I64d", &l[i], &r[i], &ans[i]);
for (int j=l[i]; j<=r[i]; ++j)
{
a[j] = LCM (a[j], ans[i]);
if (a[j] > 1e9)
{
flag = true; break;
}
}
} if (flag)
{
puts ("Stupid BrotherK!"); continue;
} for (int i=; i<=q; ++i)
{
LL k = a[l[i]];
for (int j=l[i]+; j<=r[i]; ++j)
{
k = GCD (k, a[j]);
}
if (k != ans[i])
{
flag = true; puts ("Stupid BrotherK!"); break;
}
} if (!flag) for (int i=; i<=n; ++i)
printf ("%I64d%c", a[i], (i==n) ? '\n' : ' ');
} return ;
} /*
Stupid BrotherK!
*/
数学 赛码 1010 GCD的更多相关文章
- 并查集+拓扑排序 赛码 1009 Exploration
		
题目传送门 /* 题意:无向图和有向图的混合图判环: 官方题解:首先对于所有的无向边,我们使用并查集将两边的点并起来,若一条边未合并之前, 两端的点已经处于同一个集合了,那么说明必定存在可行的环(因为 ...
 - 递推DP 赛码 1005 Game
		
题目传送门 /* 递推DP:官方题解 令Fi,j代表剩下i个人时,若BrotherK的位置是1,那么位置为j的人是否可能获胜 转移的时候可以枚举当前轮指定的数是什么,那么就可以计算出当前位置j的人在剩 ...
 - 贪心 赛码 1001 Movie
		
题目传送门 /* 贪心:官方题解: 首先我们考虑如何选择最左边的一个区间 假设最左边的区间标号是i, 那选择的另外两个区间的左端点必定要大于Ri 若存在i之外的j, 满足Rj<Ri, 那么另外两 ...
 - 赛码网算法: 上台阶 ( python3实现 、c实现)
		
上台阶 题目描述 有一楼梯共m级,刚开始时你在第一级,若每次只能跨上一级或二级,要走上第m级,共有多少走法?注:规定从一级到一级有0种走法. 输入输入数据首先包含一个整数n(1<=n<=1 ...
 - 赛码网算法: 军训队列( python实现 )
		
军训队列 题目描述某大学开学进行军训队列训练,将学生从一开始按顺序依次编号,并排成一行横队,训练的规则如下:从头开始一至二报数,凡报到二的出列剩下的依次向前靠拢,再从头开始进行一至三报数,凡报到三的出 ...
 - ACM 五一杭电赛码"BestCoder"杯中国大学生程序设计冠军赛小记
		
对于这项曾经热爱的竞赛,不得不说这是我最后一年参加ACM比赛了,所以要珍惜每一次比赛的机会. 五一去杭电参加了赛码"BestCoder"杯中国大学生程序设计冠军赛,去的队伍包括了今 ...
 - [bzoj]2705: [SDOI2012]Longge的问题[数论][数学][欧拉函数][gcd]
		
[bzoj]P2705 OR [luogu]P2303 Longge的问题 Description Longge的数学成绩非常好,并且他非常乐于挑战高难度的数学问题.现在问题来了:给定一个整数N,你需 ...
 - 数学--数论--HDU 5223 - GCD
		
Describtion In mathematics, the greatest common divisor (gcd) of two or more integers, when at least ...
 - 个人训练记录-赛码"bestcoder"杯中国大学生程序设计冠军赛
		
A.Movie 题意是给n个线段,要求求出是否存在三个不相交的线段,是的话输出yes,否则输出no.根据贪心的想法,可以先找出右端点r'最小的线段,他是三条线段中最左的那条,再找出左端点l'最大的线段 ...
 
随机推荐
- wap版百度hi给你飞速的赶脚 赶紧登陆手机百度hi吧
			
百度hi自然是百度自己的产品,如果你是做国内市场,这个产品应该要用一下.经常逛百度空间,有时实在受不了它的加载速度,(当然,这个跟你的网速.电脑配置.你所使用的百度空间模板等因素有关),我们看看百度空 ...
 - HDU 1176免费馅饼     DP数塔问题转化
			
L - 免费馅饼 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submit Sta ...
 - No bootable device-insert boot disk and press any key
			
macbook air 2012 mid. 长按关机键关机,按开机键,然后长按option键,会出现可以选择启动的磁盘块,选择要启动的磁盘进入即可.
 - mybatis处理集合、循环、数组和in查询等语句的使用
			
在Mybatis的xml配置中使用集合,主要是用到了foreach动态语句. foreach的参数: foreach元素的属性主要有 item,index,collection,open,separa ...
 - Android 中的异步下载
			
网上提到最多的就是利用AsyncTask进行异步下载,用android-async-http第三方库的也比较多.这里写点注意事项. 先说说android-async-http,这个库发送请求利用thr ...
 - MySQL的LIMIT与分页优化
			
在系统中需要进行分页操作的时候,我们通常会使用LIMIT加上偏移量的办法实现,同时加上合适的ORDER BY子句.如果有对应的索引,通常效率会不错,否则,MySQL需要做大量的文件排序操作. 一个非常 ...
 - sqlserver的执行计划
			
一:执行计划生成过程 说到执行计划,首先要知道的是执行计划大概生成的过程,这样就可以做到就心中有数了,下面我画下简图: 1. 分析过程 这三个比较容易理解,首先我们要保证sql的语法不能错误,sele ...
 - wget 增加单个文件下载限制大小
			
增加了参数 -M --limit-size 使用方法 -M 5m 或者 -M 500k 或者 --limit-size=5m 或者 --limit-size=500k 下载地址 http://pan. ...
 - 中石油—2的幂次方(power)
			
问题 E: 2的幂次方(power) 时间限制: 1 Sec 内存限制: 64 MB提交: 38 解决: 19[提交][状态][讨论版] 题目描述 任何一个正整数都可以用2的幂次方表示.例如:13 ...
 - Heap:Sunscreen(POJ 3614)
			
晒太阳 题目大意:一堆牛,为了避免晒太阳会灼烧自己,然后他们自己有自己的防晒指数(一个区间),防晒霜可以提高防晒因数SPF,大了不行小了不行,现在有一桶防晒霜,他们提供一定的SPF,但是最多可以提供k ...