HDU 5317 RGCDQ(2015多校联合)

本文介绍了一道算法题目,要求在给定区间内找出任意两数素因子个数最大公约数的最大值。通过预处理得到每个数的素因子个数,并使用前缀和优化查询过程,最终高效解决该问题。

题目链接:戳我

题目大意

函数 \(F(x)\) = x 的素因子个数,给定一个区间 L,R 求 \(max(GCD(F(i), F(j))\)
其中\((L <= i < j <= R)\),即区间内任意两个不相等的两个数的最大公约数的 最大值
数据范围 \(2<=L < R<=1000000\)

样例解释

2 // T
2 3 //L=2, R=3,f(2)=1, f(3)=1,故答案为 1

解题思路

因为R最大为\(10^6\),且\(2*3*5*7*11*13*17 = 510510 < 10^6 < 2*3*5*7*11*13*17*19\)
所以一定存在
\(f(x) < 8\),
\((2<=x<=10^6)\)
f(x)很容易 求得
故只需要知道L R区间内有多少个 1,2...7 即可
可以 用s[i][j]保存前i个F中j的个数

代码

//Author LJH
//www.cnblogs.com/tenlee
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cctype>
#include <cmath>
#include <algorithm>
#include <vector>
#include <queue>
#include <stack>
#include <map>
#define clc(a, b) memset(a, b, sizeof(a))
using namespace std;

const int inf = 0x3f;
const int INF = 0x3f3f3f3f;
const int maxn = 1e6+5;
int nu[maxn], s[maxn][10], ha[10];

void Init()
{
    clc(nu, 0);
    clc(s, 0);
    for(int i = 2; i < maxn; i++)
    {
        if(nu[i]) continue;
        nu[i] = 1;
        for(int j = 2; j * i < maxn; j++)
        {
            nu[j*i]++;
        }
    }
    s[2][1] = 1;
    for(int i = 3; i < maxn; i++)
    {
        for(int j = 1; j <= 7; j++)
        {
            s[i][j] = s[i-1][j];
        }
        s[i][nu[i]]++;   
    }
}

int GCD(int x, int y)
{
    return y == 0 ? x : GCD(y, x%y);
}
int main()
{
    int l, r, T, k;
    int nlr[10], a[20];
    Init();
    scanf("%d", &T);
    while(T--)
    {
        scanf("%d %d", &l, &r);
        k = 0;
        for(int i = 1; i <= 7; i++)
        {
            nlr[i] = s[r][i] - s[l][i];
            if(i == nu[l] ) nlr[i]++;
            //printf("i = %d, %d\n", i, nlr[i]);
            if(nlr[i] >= 2)
            {
                a[k++] = i; a[k++] = i;
            }
            else if(nlr[i] == 1)a[k++] = i;
        }
        int ma = 1;
        for(int i = 0; i < k-1; i++)
        {
            for(int j = i+1; j < k; j++)
            {
                ma = max(GCD(a[i], a[j]), ma);
            }
        }
        printf("%d\n", ma);
    }
    return 0;
}

转载于:https://www.cnblogs.com/tenlee/p/4684166.html

**高专业实习管理平台设计与实现** 本设计项目旨在构建一个服务于高等院专业实习环节的综合性管理平台。该系统采用当前主流的Web开发架构,基于Python编程语言,结合Django后端框架与Vue.js前端框架进行开发,实现了前后端逻辑的分离。数据存储层选用广泛应用的MySQL关系型数据库,确保了系统的稳定性和数据处理的效率。 平台设计了角色协同工作的管理模型,具体包括系统管理员、院系负责人、指导教师、实习单位对接人以及参与实习的学生。各角色依据权限访问不同的功能模块,共同构成完整的实习管理流程。核心功能模块涵盖:基础信息管理(如院系、专业、人员信息)、实习过程管理(包括实习公告发布、实习内容规划、实习申请与安排)、双向反馈机制(单位评价与学生反馈)、实习支持与保障、以及贯穿始终的成绩评定与综合成绩管理。 在技术实现层面,后端服务依托Django框架的高效与安全性构建业务逻辑;前端界面则利用Vue.js的组件化特性与LayUI的样式库,致力于提供清晰、友好的用户交互体验。数据库设计充分考虑了实习管理业务的实体关系与数据一致性要求,并保留了未来功能扩展的灵活性。 整个系统遵循规范的软件开发流程,从需求分析、系统设计、编码实现到测试验证,均进行了轮迭代与优化,力求在功能完备性、系统性能及用户使用体验方面达到较高标准。 **核心术语**:实习管理平台;Django框架;MySQL数据库;Vue.js前端;Python语言。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
在电磁散射与雷达技术的研究中,涉及粗糙表面电磁特性模拟的核心概念包括统计参数化建模方法、不同电场矢量方向的极化模式、特定方向的能量反射现象、理想化波前模型以及具有随机起伏特征的界面。以下是对这些要点的系统阐述: 统计参数化建模是一种基于表面统计特征描述其不规则性的电磁散射计算方法,尤其适用于均方根高度较小的粗糙界面在微波至毫米波频段的散射特性分析。 水平极化与垂直极化分别指电场矢量平行于地面和垂直于地面的振动状态。在雷达探测中,采用不同的极化模式有助于提升目标辨识度并抑制环境干扰。 当电磁波与物体相互作用时,部分能量沿接近入射方向返回,这种现象称为反向散射。其在雷达系统的探测灵敏度与目标特征分析中具有关键作用。 平面波是在均匀介质中传播的理想波型,其电场与磁场分布保持一致的相位关系,常作为理论简化模型用于电磁问题的解析与数值计算。 粗糙界面指具有随机起伏特征的表面,其不规则程度可通过均方根高度进行量化。这种结构特性会改变电磁波的传播路径与能量分布,进而影响信号的接收与处理。 相关压缩文件可能包含了实现上述建模方法的程序代码,通常采用数值计算语言编写,用于模拟不同极化状态下粗糙表面对平面波的反向散射响应。通过此类仿真,能够预测各类场景下的散射参数,为雷达系统设计与遥感数据解译提供理论依据。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值