博客
关于我
bzoj 2956: 模积和
阅读量:259 次
发布时间:2019-03-01

本文共 1174 字,大约阅读时间需要 3 分钟。

题意:求
nimj(n mod i)(m mod j)(i!=j)

题解:

我各种sb错误荒废了一上午啊啊啊。

先无视限制:即

ni(n mod i)mj(m mod j)
同bzoj 1257()
然后要减去相等的情况。
min(n,m)i(n mod i)(m mod i)
=min(n,m)i(nnii)(mmii)
=min(n,m)i(nm)(nim+min)+nimii2
然后就能分块了。

注意:乘一步mod一步啊啊啊!!!

code:

#include
#include
#include
#include
#define LL long longusing namespace std;const LL mod=19940417,inv=3323403;LL sum(LL l,LL r){ return ((LL)(r-l+1)*(LL)(l+r)/2)%mod;}LL sum_2(LL n){ return (LL)n*(LL)(n+1)%mod*(LL)(2*n+1)%mod*inv%mod;}LL solve(LL n){ LL ans=0;LL pos; for(LL i=1;i<=n;i=pos+1) { pos=(n/(n/i)); ans=(ans+((LL)n*(pos-i+1)-(LL)(n/i)*sum(i,pos))%mod)%mod; } return ans;}LL solve2(LL n,LL m){ if(n>m) swap(n,m); LL ans=0;LL pos; for(LL i=1;i<=n;i=pos+1) { pos=min(n/(n/i),m/(m/i)); LL t1=n*m%mod*(pos-i+1)%mod,t2=sum(i,pos)%mod*(n*(m/i)%mod+m*(n/i)%mod)%mod,t3=(m/i)*(n/i)%mod*(sum_2(pos)-sum_2(i-1)+mod)%mod; t3=(t3+mod)%mod; ans=((ans+(t1-t2+t3)%mod)+mod)%mod; } return ans;}LL n,m;int main(){ scanf("%lld %lld",&n,&m); printf("%lld",((solve(n)*solve(m)%mod-solve2(n,m))%mod+mod)%mod);}

转载地址:http://rdza.baihongyu.com/

你可能感兴趣的文章
mysql授权用户,创建用户名密码,授权单个数据库,授权多个数据库
查看>>
mysql排序查询
查看>>
MySQL排序的艺术:你真的懂 Order By吗?
查看>>
MySQL排序的艺术:你真的懂 Order By吗?
查看>>
Mysql推荐书籍
查看>>
Mysql插入数据从指定选项中随机选择、插入时间从指定范围随机生成、Navicat使用存储过程模拟插入测试数据
查看>>
MYSQL搜索引擎
查看>>
mysql操作数据表的命令_MySQL数据表操作命令
查看>>
mysql操作日志记录查询_如何使用SpringBoot AOP 记录操作日志、异常日志?
查看>>
MySQL支持的事务隔离级别,以及悲观锁和乐观锁的原理和应用场景?
查看>>
mysql支持表情
查看>>
MySQL支撑百万级流量高并发的网站部署详解
查看>>
MySQL改动rootpassword的多种方法
查看>>
mysql数据分组索引_MYSQL之索引配置方法分类
查看>>
mysql数据取差,mysql屏蔽主外键关联关系
查看>>
MySQL数据和Redis缓存一致性方案详解
查看>>
MySQL数据和Redis缓存一致性方案详解
查看>>
Mysql数据库 InnoDB存储引擎中Master Thread的执行流程
查看>>
MySQL数据库 范式
查看>>
Mysql数据库B-Tree索引
查看>>