Luogu P11036 GCD 与 LCM 问题 [ 绿 ] [ 构造 ] [ 数论 ] [ adhoc ]
Luogu P11036 GCD 与 LCM 问题:梦熊的题真是又神又逆天。
思路
观察到有个奇数的特殊性质,我们尝试从奇数构造入手。
先来尝试带入极端数据,对于 \(\gcd\),我们可以把 \(b=1\) 的情况先带进去看看。
\]
\]
\]
奇数情况
我们尝试在 \(a\) 为奇数的情况解这个方程。
首先我们依然是进行极端构造,先把 \(c=1\) 带入,可得:
\]
发现 \(d\) 被消去,我们无法求出 \(d\),所以我们要让 \(d\) 的系数加倍,以防止被抵消。
于是我们尝试把 \(c=2\) 带入,并且强制让 \(d\) 变成奇数,这样才能让这个 \(2\) 起效果。
\]
\]
其中,\(a,d\) 皆为奇数,所以成立。
所以:
\]
场上我只想得出这个奇数构造了,偶数的没有想出来。现在看来我就是个傻逼。
偶数情况
我们发现奇数情况是不适用偶数情况的,所以要另辟蹊径。
于是我们要想办法让偶数情况变成奇数情况。
怎么变?
尝试把 \(a\) 中所有的 \(2\) 提出来,\(a\) 就变成奇数了!
这时:
\]
其中 \(p\) 为奇数。
所以我们可以对 \(p\) 的情况进行构造,然后将 \(c,d\) 同时乘上 \(2^k\) 输出就好了。
为什么不会超过限制?因为 \(d\) 最多才 \(a+2\),也就是说他最多比 \(a\) 要大 \(2^30\),极端情况下也只有 \(2^{30}+2^{29}=1610612736\),刚好卡过!
注意 \(b\) 不用扩倍,因为他立刻就能被消去。
总结
这题其实重点在于考虑从特殊性质入手,然后进行极端构造,最后尝试把难以解决的情况化为之前我们以及解决了的问题。是一道很好的构造练习题。
代码
#include <bits/stdc++.h>
#define fi first
#define se second
#define lc (p<<1)
#define rc ((p<<1)|1)
using namespace std;
typedef long long ll;
typedef pair<int,int> pi;
int t;
ll a,b,c,tms;
int main()
{
	ios::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);
	cin>>t;
	while(t--)
	{
		cin>>a;
		tms=1;
		while(a%2==0)
		{
			a/=2;
			tms*=2;
		}
		cout<<1<<' '<<2*tms<<' '<<(a+2)*tms<<endl;
	}
	return 0;
}
Luogu P11036 GCD 与 LCM 问题 [ 绿 ] [ 构造 ] [ 数论 ] [ adhoc ]的更多相关文章
- HDOJ 4497 GCD and LCM
		组合数学 GCD and LCM Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others) ... 
- hdu 4497 GCD and LCM 数学
		GCD and LCM Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=4 ... 
- GCD 与 LCM UVA - 11388
		题目链接: https://cn.vjudge.net/problem/23709/origin 本题其实有坑 数据大小太大, 2的32次方,故而一定是取巧的算法,暴力不可能过的 思路是最大公因数的倍 ... 
- 简单数论总结1——gcd与lcm
		并不重要的前言 最近学习了一些数论知识,但是自己都不懂自己到底学了些什么qwq,在这里把知识一并总结起来. 也不是很难的gcd和lcm 显而易见的结论: 为什么呢? 根据唯一分解定理: a和b都可被分 ... 
- poj 2429 GCD & LCM Inverse 【java】+【数学】
		GCD & LCM Inverse Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 9928 Accepted: ... 
- HDU 4497 GCD and LCM (合数分解)
		GCD and LCM Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others)Total ... 
- hdu4497 GCD and LCM
		GCD and LCM Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others) Total S ... 
- HDU 4497 GCD and LCM(数论+容斥原理)
		GCD and LCM Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others)Total ... 
- 数论——算数基本定理 - HDU 4497 GCD and LCM
		GCD and LCM Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others)Total ... 
- HDU4497——GCD and LCM
		这个题目挺不错的,看到是通化邀请赛的题目,是一个很综合的数论题目. 是这样的,给你三个数的GCD和LCM,现在要你求出这三个数有多少种可能的情况. 对于是否存在这个问题,直接看 LCM%GCD是否为0 ... 
随机推荐
- 2024御网杯信息安全大赛个人赛wp_2024-11-27
			MISC题解 题目附件以及工具链接: 通过网盘分享的文件:御网杯附件 链接: https://pan.baidu.com/s/1LNA6Xz6eZodSV0Io9jGSZg 提取码: jay1 --来 ... 
- noip2024
			NOIP2024 游记 考试之前一直有很多话想在游记里说,但考完后又不知道该说些什么.这六个月的集训时光仿佛像一场梦一般. 怒砍\([60, 100] + 0 + 0 + 0\) 作为一个只学了不到一 ... 
- 第三方css动画库
			https://animate.style///安装npm install animate.css --save //引入 import 'animate.css';//使用 <h1 class ... 
- solon 集成 kafka-clients
			使用 kafka-clients 原本是比较简单的事情.但有些同学习惯了 spring-kafka 后,对原始 java 接口会陌生些.会希望有个集成的示例. <dependency> & ... 
- Dockerfile轻松打包jar包生成docker
			1. 创建java目录 mkdir /home/java/ cd /home/java/ 2. 创建Dockerfile #FROM openjdk:8-jdk-alpine #ADD *.jar a ... 
- Centos查找Tomcat路径并重启
			[root@devrestcloud ~\]# find / -name \*tomcat\* [root@devrestcloud ~]# cd /usr/tomcat/apache-tomcat- ... 
- Flutter TextField设置值后光标位置偏移
			Flutter TextField设置值后光标位置偏移 一般用controller设置值是这样设置的 TextEditingController controller = TextEditingCon ... 
- Terraform Aliyun 创建ecs, kubernetes 实例
			Terraform Aliyun 创建ecs, kubernetes 实例 terraform demo for aliyun 创建vpc, 网关, EIP, ecs, kubernetes, Ser ... 
- 刷到一个 MLSQL 语言
			在 https://www.infoq.cn/video/2vFUBYfxFcoFWmSm5WOj 刷到一个 MLSQL 语言,主页 https://www.mlsql.tech/home ,意思是用 ... 
- 【前端】【H5 API】addEventListener监听网络状态的变动
			WebviewObject Webview窗口对象,用于操作加载HTML页面的窗口 属性 id:webview窗口的标识 方法:监听 addEventListener 添加事件监听器 wobj.add ... 
