蓝桥杯每日一题:公约数(gcd)

题目描述:

给定两个正整数 a 和 b。

你需要回答 q 个询问。

每个询问给定两个整数 l,r,你需要找到最大的整数 x,满足:

  1. x 是 a和 b 的公约数。
  2. l≤x≤r。
输入格式

第一行包含两个整数 a,b。

第二行包含一个整数 q。

接下来 q 行,每行包含两个整数 l,r。

输出格式

每个询问输出一行答案,即满足条件的最大的 x�,如果询问无解,则输出 −1−1。

数据范围

前六个测试点满足 1≤a,b≤100,1≤q≤20。
所有测试点满足 1≤a,b≤10^9,1≤q≤10^4,1≤l≤r≤10^9。

输入样例:
9 27
3
1 5
10 11
9 11
输出样例:
3
-1
9

 解题思路:

设d为(a,b)的最大公约数,x为d所有约数,p为质约数;

有图可知 a,b质约数和x相同,x为d的约数,因此求出d的所以有约数再排序,找出l-r的最大值即可.

参考代码:

###暴力
```
#include <iostream>
#include <cstring>
#include <algorithm>

using namespace std;
const int N = 1350;
int p[N];
int a,b,cnt;

int gcd(int a,int b)
{
    return b ? gcd(b,a%b) : a;
}

void solve(int a,int b)
{
    int d = gcd(a,b);
    for(int i=1;i<=d/i;i++)
    {
        if(d%i==0)
        {
            p[cnt++] = i;
            if(i!=d/i) p[cnt++] = d/i;
        }
    }
    sort(p,p+cnt);
}

int main()
{
    scanf("%d%d", &a, &b);
    solve(a,b);
    
    int n;
    cin>>n;
    while (n -- )
    {
        int l,r;
        cin>>l>>r;
        bool st = false;
        for(int i=cnt-1;i>=0;i--)
        {
            if(p[i]>=l && p[i]<=r)
            {
                printf("%d\n",p[i]);
                st = true;
                break;
            }
        }
        if(!st) puts("-1");
    }
    return 0;
}
```
###二分
```
#include <iostream>
#include <cstring>
#include <algorithm>
#include <vector>

using namespace std;
const int N = 1350;
int p[N];
int a,b,cnt;

int gcd(int a,int b)
{
    return b ? gcd(b,a%b) : a;
}

void solve(int a,int b)
{
    int d = gcd(a,b);
    for(int i=1;i<=d/i;i++)
    {
        if(d%i==0)
        {
            p[cnt++] = i;
            if(i!=d/i) p[cnt++] = d/i;
        }
    }
    sort(p,p+cnt);
}

int main()
{
    scanf("%d%d", &a, &b);
    solve(a,b);
    
    int n;
    cin>>n;
    while (n -- )
    {
        int l,r;
        cin>>l>>r;
        int L = 0,R = cnt - 1;
        while(L<R)
        {
            int mid = L + R + 1 >> 1;
            if(p[mid]<=r) L = mid;
            else R = mid - 1;
        }
        if(p[L]>=l) printf("%d\n",p[L]);
        else puts("-1");
    }
    return 0;
}
```

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

理解Go语言中的并发和并行

即使有多年的并发编程经验,有些开发人员也可能无法清楚地理解并发(concurrency)和并行(parallelism)之间的区别。下面我们以一个真实的例子来说明:一家咖啡店。 在这家咖啡店中,一名服务员负责接收订单并使用一台咖啡机进行准备。顾客下订单,然后等待他们的咖啡。 …

Gateway是什么?(SpringCloudAlibaba组件)

1、网关介绍 **网关(Gateway)又称网间连接器、协议转换器。网关在传输层上以实现网络互连&#xff0c;是最复杂的网络互连设备&#xff0c;仅用于两个高层协议不同的网络互连。**网关的结构也和路由器类似&#xff0c;不同的是互连层。网关既可以用于广域网互连&#xff0c;也可…

IP证书申请

目录 申请IP证书的基本条件&#xff1a; 申请和使用公网IP证书的过程&#xff1a; 为什么需要申请IP地址证书&#xff1f; 申请IP证书&#xff1a; IP证书又称公网IP地址证书&#xff0c;是一种特殊的SSL/TLS证书&#xff0c;其作用原理和普通的域名证书很像&#xff0c;域…

使用 Cloudflare 和全栈框架实现快速开发

去年 Cloudflare 发布了一系列新功能&#xff0c;使在 Cloudflare 上部署 Web 应用程序变得更加容易&#xff0c;我们看到 Astro、Next.js、Nuxt、Qwik、Remix、SolidStart、SvelteKit 和其他托管 Web 应用程序的大幅增长。 近日 Cloudflare 对这些 Web 框架的集成模块进行了重…

思诺流体邀您探索科技前沿2024年第13届生物发酵展

参展企业介绍 保定思诺流体科技有限公司是一家集研发、生产、销售于一体的高新技术企业。从事蠕动泵、蠕动泵软管、蠕动泵OEM产品、蠕动泵灌装系统等的研发、生产与销售。产品在科研实验室、化工、印刷、环保、水处理等领域得到了广泛应用。 “思诺”取自“Signal”的英…

Linux学习记录20——文件的隐藏权限

一.学习的内容 Linux系统中的文件除了具备一般权限和特殊权限之外&#xff0c;还有一种隐藏权限&#xff0c;即被隐藏起来的权限&#xff0c;默认情况下不能直接被用户发觉。既然叫隐藏权限&#xff0c;那么使用常规的ls命令肯定不能看到它的真面目。隐藏权限的专用设置命令是 …

认识JAVA语言(一)扩充

Java语言的程序控制结构 (2.5) 在Java语言中&#xff0c;程序的流程控制对于代码执行的逻辑有着至关重要的作用。通过条件控制和循环控制&#xff0c;程序可以做出决策、重复执行任务&#xff0c;并在合适的时间退出。本章将详细介绍这些结构&#xff0c;并通过代码示例和表格来…

D1084是一款具有5A输出能力、低压差为1.5V的三端稳压器。采用TO-220、TO-263和TO-252封装形式

1、 概述&#xff1a; D1084是一款具有5A输出能力、低压差为1.5V的三端稳压器。输出电压可通过电位器调节或1.5V, 1.8V, 3.3V三个固定电压版。内含电流限制和热保护功能&#xff0c;防止任何过载时产生过高的结温。D1084系列电路有标准TO-220、TO-263和TO-252封装形式。 2、 典…

短剧APP开发:探索剧情新领域,畅享精彩短剧时光

随着移动互联网的快速发展&#xff0c;短剧作为一种新兴的内容形式&#xff0c;以其短小精悍、情节紧凑的特点&#xff0c;逐渐受到广大用户的喜爱。为了满足用户对短剧内容的日益增长需求&#xff0c;我们决定开发一款全新的短剧APP&#xff0c;为用户带来前所未有的观剧体验。…

鼠标灵敏度怎么调,鼠标灵敏度怎么调最稳

鼠标和键盘是操作计算机过程中使用最频繁的设备之一,用电脑的时,我敢说你一定离不开鼠标。有些用户发现鼠标不太好用,尤其是在游戏时,总觉得鼠标移动太慢了。另外,如果你感觉鼠标按键失灵、鼠标单击变双击以及反应迟钝等等,出现这样的问题,应该是鼠标灵敏度没有调整好。…

先锋阀门带您领略2024第13届生物发酵装备展

参展企业介绍 温州先锋阀门有限公司坐落于【中国阀门城】---温州市龙湾&#xff0c;是一家集研发、设计、制造、销售和服务为一体的科技创新型企业。拥有10多项国家专利&#xff0c;三个产品荣获中国通用机械工业协会颁发的(中国国际阀门博览会)银奖称号&#xff0c;部分产品还…

干货 | 探索CUTTag:从样本到文库,实验步步为营!

CUT&Tag&#xff08;Cleavage Under Targets and Tagmentation&#xff09;是一种新型DNA-蛋白互作研究技术&#xff0c;主要用于研究转录因子或组蛋白修饰在全基因组上的结合或分布位点。相比于传统的ChIP-seq技术&#xff0c;CUT&Tag反应在细胞内进行&#xff0c;创新…

win10鼠标无限转圈圈是什么原因,win10系统鼠标无限转圈圈

win10鼠标无限转圈圈是什么原因?一般后台有程序在运行,鼠标出现圆圈转动则代表正在加载中,等待一会就好了。若如果转了好久的圈圈,程序没有响应,点击桌面也没有反应,则尝试打开任务管理器,将未响应或异常的程序强制结束掉。其实,出现这种情况,有可能是win10系统中的一…

HarmonyOS4.0 ArkUI常用组件

一、Image 语法&#xff1a; Image(src:string|PixelMap|Resource)使用方式&#xff1a; string格式&#xff1a;用来加载网络图片&#xff0c;需要在module.json5中申请网络访问权限&#xff1a;ohos.permission.INTERNET Image("http://xxx.png")PixelMap格式&am…

医保是如何报销的

《医保是如何报销的》 这是罗师兄的原创文章 预计5-6分钟读完 作者&#xff1a;罗师兄 地球号&#xff1a;luoyun515 很多时候大家听到医保报销比例80%&#xff0c;85%&#xff0c;90%等&#xff0c; 但真正报销后&#xff0c; 实际花费跟报销额度根本达不到这么高&#…

LeetCode-78. 子集【位运算 数组 回溯】

LeetCode-78. 子集【位运算 数组 回溯】 题目描述&#xff1a;解题思路一&#xff1a;回溯&#xff0c;回溯三部曲解题思路二&#xff1a;0解题思路三&#xff1a;0 题目描述&#xff1a; 给你一个整数数组 nums &#xff0c;数组中的元素 互不相同 。返回该数组所有可能的 子…

【OTA】STM32-OTA升级——持续更新

【OTA】STM32-OTA升级——持续更新 文章目录 前言一、ymodem串口协议1、Ymodem 协议2、PC3、蓝牙4、WIFI云平台 二、UDS车载协议1.UDS协议 总结 前言 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 一、ymodem串口协议 1、Ymodem 协议 STM32 Ymodem …

上海亚商投顾:创业板指缩量下跌 有色等周期股逆势大涨

上海亚商投顾前言&#xff1a;无惧大盘涨跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。 一.市场情绪 沪指4月3日小幅调整&#xff0c;创业板指跌超1%&#xff0c;黄白二线有所分化。周期股持续走强&#xff0c;其…

电瓶车充电桩主板功能全解析

电瓶车充电桩主板是充电桩的核心部件&#xff0c;其功能涵盖了多个方面&#xff0c;以确保充电过程的安全、高效和便捷。主要功能包括&#xff1a; 智能化充电管理&#xff1a;电瓶车充电桩主板内置智能调度系统&#xff0c;可通过监测电池状态和控制充电流程&#xff0c;实现对…

【STL学习】(3)vector容器

前言 本章主要内容为两个部分&#xff1a; vector是什么&#xff1f;vector常用接口的使用。 一、vector的介绍 vector是表示可变大小数组的容器就像数组一样&#xff0c;vector也采用的连续空间来存储元素。也意味着可以采用下标对vector的元素进行访问&#xff0c;和数组一样…