前言:体验到了推式子的快感orz

题目大意:求$\varphi(n)*\varphi(m)*\sum_{n\ mod\ k+m\ mod\ k\geq k} \varphi(k)\ mod\ 998244353$

---------------------------

设$n=q_1k+r_1,m=q_2k+r_2$,那么$q_1=\lfloor \frac{n}{k} \rfloor,q_2=\lfloor \frac{m}{k} \rfloor$。

$n+m=(q_1+q_2)k+r_1+r_2$

$(n+m)-(q_1+q_2)k=r_1+r_2$

$\lfloor \frac{n+m}{k} \rfloor-\lfloor \frac{n}{k} \rfloor-\lfloor \frac{m}{k} \rfloor=r_1+r_2=1$

所以现在变为:找到满足上式的$k$。

我们先给出一个式子:

$ans=\sum\limits_{i=1}^{n+m}\varphi(k)*\lfloor \frac{n+m}{k} \rfloor-\sum\limits_{i=1}^n \varphi(k)*\lfloor \frac{n}{k} \rfloor-\sum\limits_{i=1}^m \varphi(k)*\lfloor \frac{m}{k} \rfloor$

这个式子是什么意思?

对于$(\lfloor \frac{n+m}{k} \rfloor-\lfloor \frac{n}{k} \rfloor-\lfloor \frac{m}{k} \rfloor)*\varphi(k)$:

如果$k$满足条件,那么系数为$1$,对答案有贡献。如果$k$不合法那么系数为$0$,对答案是没有贡献的。所以上面给出的式子可以计算所有合法的答案。

现在我们尝试对$\sum\limits_{i=1}^n \varphi(k)*\lfloor \frac{n}{k} \rfloor$进行化简。

有这样一个关系:$\sum\limits_{i=1}^n i=\sum\limits_{i=1}^n \sum\limits_{k|i}\varphi(k)=\sum\limits_{i=1}^n \varphi(k)*\lfloor \frac{n}{k} \rfloor$

证明:$\sum\limits_{i=1}^n i=\sum\limits_{i=1}^n \sum\limits_{k|i}\varphi(k)$

对于一个数$i$,在小于等于它的数中有这样的关系:

1.最大公约数为$1$,记为$G_1$,个数显然是$\varphi(i)$

2.最大公约数为$2$,记为$G_2$,个数是$\varphi(i/2)$

$\cdots$

i.最大公约数为$i$,记为$G_i$,个数为$1$。

这些集合的并集大小为$i$,所以上述等式成立。

现在来看$\sum\limits_{i=1}^n \sum\limits_{k|i}\varphi(k)=\sum\limits_{i=1}^n \varphi(k)*\lfloor \frac{n}{k} \rfloor$

对于左式,其意义为考虑每个$i$对答案的贡献;而对于右式,其意义为考虑每个合法的$k$对答案的贡献。二者对于答案的总贡献是相同的,所以等式成立。

经过化简,最终答案为$\varphi(n)*\varphi(m)*n*m$

代码:

#include<bits/stdc++.h>
#define int long long
using namespace std;
const int mod=;
int n,m,ans;
inline int phi(int x)
{
int res=x,m=x;
for (int i=;i*i<=m;i++)
{
if (x%i) continue;
res=res/i*(i-);
while(!(x%i)) x/=i;
}
if (x>) res=res/x*(x-);
return res%mod;
}
signed main()
{
cin>>n>>m;
ans=((n%mod)*(m%mod))%mod;
ans*=phi(n),ans%=mod;
ans*=phi(m),ans%=mod;
printf("%lld",(ans+mod)%mod);
return ;
}

【BZOJ4173】数学 题解(数论)的更多相关文章

  1. TYUT程序设计入门第四讲练习题题解--数论入门

    程序设计入门第四讲练习题题解--数论入门 对于新知识点的学习,需要不断地刷题训练,才能有所收获,才能更好地消化知识点. 题组链接: 程序设计入门第四讲练习题--数论 by vjudge 题解: A. ...

  2. bzoj4173 数学

    bzoj4173 数学 欧拉\(\varphi\)函数,变形还是很巧妙的 求: \[\varphi(n)\cdot\varphi(m)\cdot\sum_{n\bmod k+m\bmod k\ge k ...

  3. HDU 1030 Delta-wave 数学题解

    给出一个数字塔,然后求沿着数字之间的边走,给出两个数字,问其路径最短的长度是多少. 看似一条搜索题目,只是有一定做题经验的人都知道,这个不是搜索题,直接搜索肯定超时. 这个是依据规律计算的数学题目. ...

  4. QBXT Day 4 数学,数论

    今天讲一讲数论吧(虽然清明讲过了) 进制转换 我们来看10这个数怎么转换成k进制 因为10=2^3+2^1,所以10就是1010 三进制也同理10=3^2+3^0,所以就是101 我们对于一个10进制 ...

  5. codeforces 446C DZY Loves Fibonacci Numbers(数学 or 数论+线段树)(两种方法)

    In mathematical terms, the sequence Fn of Fibonacci numbers is defined by the recurrence relation F1 ...

  6. interesting Integers(数学暴力||数论扩展欧几里得)

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAwwAAAHwCAIAAACE0n9nAAAgAElEQVR4nOydfUBT1f/Hbw9202m0r8

  7. 【BZOJ2742】【HEOI2012】Akai的数学作业 [数论]

    Akai的数学作业 Time Limit: 10 Sec  Memory Limit: 128 MB[Submit][Status][Discuss] Description 这里是广袤无垠的宇宙这里 ...

  8. POJ 3252 Round Numbers 数学题解

    Description The cows, as you know, have no fingers or thumbs and thus are unable to play Scissors, P ...

  9. Light OJ 1005 - Rooks 数学题解

    版权声明:本文作者靖心.靖空间地址:http://blog.csdn.net/kenden23/,未经本作者同意不得转载. https://blog.csdn.net/kenden23/article ...

随机推荐

  1. robotframework日志输出中文乱码以及robotframework常用关键字-笔者亲测

    一.环境说明 python版本:3.7.3 robotframework版本:3.1 robotframwork-ride版本:1.7.4.2 二.问题描述

  2. 二、python 中五种常用的数据类型

    一.字符串 单引号定义: str1 = 'hello' 双引号定义: str1 = "hello" 三引号定义:""" 人生苦短, 我用python! ...

  3. Flask 基础组件(七):蓝图

    1 蓝图资源 蓝图有自己的目录,它的所有资源都在其目录下.蓝图的资源目录是由创建Blueprint对象时传入的模块名”__name__”所在的位置决定的.同时,我们可以指定蓝图自己的模板目录和静态目录 ...

  4. 数据分析03 /基于pandas的数据清洗、级联、合并

    数据分析03 /基于pandas的数据清洗.级联.合并 目录 数据分析03 /基于pandas的数据清洗.级联.合并 1. 处理丢失的数据 2. pandas处理空值操作 3. 数据清洗案例 4. 处 ...

  5. Python之爬虫(二十) Scrapy爬取所有知乎用户信息(上)

    爬取的思路 首先我们应该找到一个账号,这个账号被关注的人和关注的人都相对比较多的,就是下图中金字塔顶端的人,然后通过爬取这个账号的信息后,再爬取他关注的人和被关注的人的账号信息,然后爬取被关注人的账号 ...

  6. Vue中使用websocket

    <template>   <div class="test">websocket demo</div></template> < ...

  7. HTML学习分享(一)

    HTML学习小结(一) 1.css的全称是什么? 2.样式表的组成 3.浏览器读取编译css的顺序? (1)HTML基本选择器 1.通配符选择器 * { margin: 0; padding: 0; ...

  8. GPO - General GPO Settings(3)

    WMI filtering Setting - Differentiating Installation Between Operations and Architecture. WMI SQL Ge ...

  9. 性能1.84倍于Ceph!网易数帆Curve分布式存储开源

    在上周刚结束的网易数字+大会上 网易数帆宣布: 开源一款名为Curve的高性能分布式存储系统, 性能可达Ceph的1.84倍! 网易副总裁.网易杭州研究院执行院长兼网易数帆总经理汪源: 基础软件的能力 ...

  10. [jvm] -- 监控和调优常用命令工具篇

    jps:java版本的ps,查看进程的信息 jps -l 输出jar包路径,类全名 jps -m 输出main参数 jps -v 输出JVM参数 jinfo:是用来查看JVM参数和动态修改部分JVM参 ...