AtCoder - 4172 Modulo Summation 贪心

开始想复杂的了 仔细观察样例后发现这个数 其实就是所有的数的LCM-1吗只有LCM-1 对所有数取模的时候才能对所有数得到MOD = a[i]-1;那么一个X%Y得到的最大值就是Y-1于是得到了这个代码#include<iostream>#include<cstdio>#include<queue>#include<cstring&...
摘要由CSDN通过智能技术生成

开始想复杂的了 仔细观察样例后发现这个数 其实就是所有的数的LCM-1吗

只有LCM-1 对所有数取模的时候才能对所有数得到MOD = a[i]-1;

那么一个X%Y得到的最大值就是Y-1

于是得到了这个代码

#include<iostream>
#include<cstdio>
#include<queue>
#include<cstring>
#include<algorithm>
#include<vector>
#include<map>
#include<sstream>
typedef long long LL;
using namespace std;

LL a[3010];
LL Gcd(LL A,LL B){
    return B==0?A:Gcd(B,A%B);
}
int main()
{
    int n;
    scanf("%d",&n);
    for(int i=1;i<=n;i++)
        scanf("%lld",&a[i]);
    LL s = a[1];
    for(int i = 2;i<=n;i++){
    
        LL gcd = Gcd(s,a[i]);
        s = s/gcd*a[i];
    }

    s--;
    LL sum=0;
    for(int i=1;i<=n;i++){
        sum+=s%a[i];
    }
    printf("%lld\n",sum);
    return 0;
}

我呢 就真的按照分析好的思路去实现了 求一遍所有数的LCM 然后-1 在逐个取模

然后轻而易举的WA 了   

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
-fno-gcse-las:此选项禁用通用局部优化(Global Common Subexpression Elimination),这是编译器用于消除重复表达式的技术。它允许编译器在不同的函数或代码块中共享变量的值。-fno-loop-nest-optimize:此选项禁用循环嵌套优化,这是一种在循环中重新排列指令的技术,提高循环的性能。-fsched-spec-load-dangerous:此选项禁用规格加载指令优化,这是一种技术,可以消除在循环中重复加载变量的指令。-fno-tree-loop-distribution:此选项禁用树循环分布优化,它是一种重新排列循环体,使得某些循环可以并行运行,从而提高性能的技术。-fno-unwind-tables:此选项禁用表格解除,它是一种技术,用于解决当出现异常时,编译器如何跟踪堆栈帧的问题。-ffp-contract=fast:此选项指定编译器使用快速浮点合同优化,它是一种技术,可以将多个浮点运算合并为一个运算,从而提高程序的性能。-fno-float-store:此选项禁用浮点存储优化,它是一种技术,可以将变量以浮点数的形式存储在内存中,从而提高程序的性能。-fno-modulo-sched-allow-regmoves:此选项禁止模块调度器在重新排序中使用寄存器移动,模块调度器是一种技术,可以重新排列指令,使其在处理器中运行更快。-fno-peel-loops:此选项禁用循环削减,它是一种技术,可以在循环的开始和结束处插入指令,以提高循环的性能。-fno-sched-pressure:此选项禁止调度器压力优化,它是一种技术,可以根据处理器负载重新排列指令,以提高程序性能。-fsplit-paths:此选项激活路径分裂优化,它是一种技术,可以在运行时将多条指令路径分割为几个部分,从而提高程序的性能。-ftree-slp-vectorize:此选项激活树结构优化,它是一种技术,可以将许多连续的指令组合成一条指令,从而提高程序的性能。-fwrapv:此选项激活符号溢出检查和溢出处理,它是一种技术,可以在运行时检查整数溢出,以便防止程序的不可预料的行为。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值