数表( table )

题目描述

有一张n×m的数表,其第i行第j列(1≤i≤n,1≤j≤m)的数值为能同时整除i和j的所有自然数之和。给定a,计算数表中不大于a的数之和。

输入

输入包含多组数据。

输入的第一行一个整数Q表示测试点内的数据组数,接下来Q行,每行三个整数n,m,a(|a|≤109)描述一组数据。

输出

对每组数据,输出一行一个整数,表示答案模231的值。

样例输入

<span style="color:#333333"><span style="color:#333333">2
4 4 3
10 10 5
</span></span>

样例输出

<span style="color:#333333"><span style="color:#333333">20
148
</span></span>

提示


solution

好题,我不会

令f[i]表示i的约数的和

题目求

gcd提出来

反演,再把gcd提出来

这就有60分了

但是这样子式子还是化不了

我们枚举i=k*d

这样子就能把nm的往前提

把询问按a排序,按a依次加入f[k]*mu[i/k]

前面的部分可以分块,后边的前缀和起来

也就是我要支持加入和查询前缀和。

树状数组即可。

#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<cmath>
#define maxn 2000006
using namespace std;
int n,Q,mu[maxn],pri[maxn],flag[maxn],sum[maxn],Max,tot;
int ans[maxn],tree[maxn];
struct node{
int n,m,a,b,id;
}s[maxn],f[maxn];
bool cmp(node A,node B){
return A.a<B.a;
}
void add(int i,int v){
for(;i<=Max;i+=i&-i)tree[i]+=v;
}
int ask(int i){
int sum=0;for(;i;i-=i&-i)sum+=tree[i];
return sum;
}
int Query(int N,int M){
int nex,sum=0;
if(N>M)swap(N,M);
for(int i=1;i<=N;i=nex+1){
nex=min(N/(N/i),M/(M/i));
//if(nex<i)exit(0);
sum+=(N/i)*(M/i)*(ask(nex)-ask(i-1));
}
return sum;
}
int main()
{
n=1000000;mu[1]=1;
for(int i=2;i<=n;i++){
if(!flag[i]){
pri[++tot]=i;mu[i]=-1;
}
for(int j=1;j<=tot&&pri[j]<=n/i;j++){
flag[i*pri[j]]=1;mu[i*pri[j]]=-mu[i];
if(i%pri[j]==0){
mu[i*pri[j]]=0;
break;
}
}
}
for(int i=1;i<=n;i++){
for(int j=i;j<=n;j+=i)f[j].a+=i;
}
for(int i=1;i<=n;i++)f[i].b=i;
sort(f+1,f+n+1,cmp);
cin>>Q;
for(int i=1;i<=Q;i++){
scanf("%d%d%d",&s[i].n,&s[i].m,&s[i].a);
s[i].id=i;
if(s[i].n>s[i].m)swap(s[i].n,s[i].m);
Max=max(Max,s[i].m);
} sort(s+1,s+Q+1,cmp);
int l=1;
for(int i=1;i<=Q;i++){
for(;f[l].a<=s[i].a&&l<=n;l++){
for(int N=f[l].b;N<=Max;N+=f[l].b)
add(N,f[l].a*mu[N/f[l].b]);
}
ans[s[i].id]=Query(s[i].n,s[i].m);
if(ans[s[i].id]<0)ans[s[i].id]+=(1<<31);
}
for(int i=1;i<=Q;i++)printf("%d\n",ans[i]);
return 0;
}

数表( table )的更多相关文章

  1. 【JZOJ3623】【SDOI2014】数表(table) 树状数组+离线+莫比乌斯反演

    题面 100 \[ Ans=\sum_{i=1}^n\sum_{j=1}^mg(gcd(i,j)) \] 其中, \[ g(d)=\sum_{i|d}i \] 我们注意到\(gcd(i,j)\)最多有 ...

  2. Lua基础之table详解

    概要:1.table特性:2.table的构造:3.table常用函数:4.table遍历:5.table面向对象 原文地址:http://blog.csdn.net/dingkun520wy/art ...

  3. Lua学习(1)——table

    table类型实现了“关联数组”.“关联数组”是一种具有特殊索引方式的数组.不仅可以通过证书来索引它,还可以使用字符串或其他类型(除了nil)来索引它.table是Lua中主要的数据结构机制(事实也是 ...

  4. lua的table库中的常用函数总结

    table是Lua语言中的一种重要的数据类型, table 的一些特性简单列举如下: (1).table 是一个“关联数组”,数组的索引可以是数字或者是字符串; (2).table 的默认初始索引一般 ...

  5. R自动数据收集第一章概述——《List of World Heritage in Danger》

      导包     library(stringr) library(XML) library(maps) heritage_parsed <- htmlParse("http://en ...

  6. RTTI (Run-Time Type Identification,通过运行时类型识别) 转

    参考一: RTTI(Run-Time Type Identification,通过运行时类型识别)程序能够使用基类的指针或引用来检查这些指针或引用所指的对象的实际派生类型.   RTTI提供了以下两个 ...

  7. C++的 RTTI 观念和用途(非常详细)

    自从1993年Bjarne Stroustrup [注1 ]提出有关C++ 的RTTI功能之建议﹐以及C++的异常处理(exception handling)需要RTTI:最近新推出的C++ 或多或少 ...

  8. R_基本统计分析_06

    summary()提供基础的统计信息 sapply(x,FUN,options)可以指定统计函数 fivenum()可以返回图基五数 Hmisc 中的describe(data)返回变量,观测的变量, ...

  9. Lua 学习之基础篇二<Lua 数据类型以及函数库 汇总>

    引言 前面讲了运算符,这里主要对Lua的数据处理相关的数据类型和函数库进行总结归纳,后面会再接着单独分开讲解具体使用. 首先因为Lua 是动态类型语言,变量不要类型定义,只需要为变量赋值. 值可以存储 ...

随机推荐

  1. elasticsearch-dsl笔记

    一.elasticsearch安装 安装java1.8以上 安装elasticsearch-rtf(https://github.com/medcl/elasticsearch-rtf) head插件 ...

  2. IDEA的使用方法(二)(代码提示)

    工欲善其事必先利其器: 在eclipse用久了代码提示对自己纯手搓代码还是不太好的,我就算是死,从楼上跳下去,也不会从了IDEA的代码提示的,在手搓了一个hello world之后,我写的是JAVA? ...

  3. 交换机基础配置之stp生成树实验

    实验的要求是以上面的拓扑图为例,查看当前根桥的所在并把三成交换机switch1指定为根桥 我们可以用show spanning-tree来查看stp的信息 输入后会显示两部分 上面一部分为当前交换机自 ...

  4. 云计算之KVM虚拟化实战

    1 基础环境规划 1.1 主机环境规划 系统版本 主机名 IP地址 内存 磁盘 CentOS6.9 kvm-node1 10.0.0.200 2G 20G CentOS6.9 kvm-node2 10 ...

  5. 微信小程序CheckBox选中事件

    1.微信小程CheckBox选中问题 <checkbox-group bindchange="checkboxChange" data-index="{{index ...

  6. 基于form表单submit提交不跳转

    方法一:target <html> <body> <form action="" method="post" target=&qu ...

  7. php-语言参考-基本语法3.1

    一,PHP代码的开始和结束标记 1,<?php 和 ?> //重点 2,<script language="php"> 和 </script> ...

  8. 使用命令行设置MySql编码格式

    使用命令行设置MySql编码格式 1.登录mysql 2.输入 SHOW VARIABLES LIKE 'character_set_%'; 3.查看 value值是否为utf8,如果不是,则使用SE ...

  9. 2019-04-11 python入门学习——配置机器及搭建开发环境

    # 在windows操作系统中搭建python 3.x版本的开发环境,开发工具为 Anaconda 3. # 1.1 下载及安装Anaconda 3 Anaconda的特点:集成性高,包含很多常用的开 ...

  10. linux通用GPIO驱动,写GPIO文件不立即生效问题解决

    Linux开发平台实现了通用GPIO的驱动,用户通过,SHell或者系统调用能控制GPIO的输出和读取其输入值.其属性文件均在/sys/class/gpio/目录下,该目录下有export和unexp ...