数表( 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. Java连接数据库的一个问题

    问题描述: 利用HTML+servlet+MySQL写一个简单的登录注册案例,抛出了异常No suitable driver found for jdbc 解决方法 将mysql-connector- ...

  2. JS之执行上下文

    执行上下文(execution context),是JS中的一个很重要的概念.它对于我们理解函数定义,执行时都做了什么有着很大的意义.理解它我们才能明白我们常说的函数声明提升,作用域链,闭包等原理. ...

  3. ethereum(以太坊)(十)--函数修饰符

    pragma solidity ^0.4.0; contract modifierTest{ uint public v1; uint constant v2 =10; //uint constant ...

  4. PHP 微信公众号真正正确的客服头像上传

    首先我们来看官方文档 这TM的搞笑呢 什么破玩意儿! 需要条件 1 需要有一个客服的账号 (废话) 2 一致jpg格式的图片(扯蛋) 完整流程 1 获取access_token 2获取账号 3 $ur ...

  5. python 获取类中除内置方法外的所有方法名

    #!/usr/bin/env python# !-*- coding:utf-8 -*- class Menu: def __init__(self): pass def updateProject( ...

  6. 493. Reverse Pairs

    // see more at https://www.youtube.com/watch?v=j68OXAMlTM4 // https://leetcode.com/problems/reverse- ...

  7. 找回被丢弃怎么找都找不回来的git中的commit

    崩溃的一天,打算提代码走人,结果切分支之后,commit丢了= =,找了三个多小时 接下来分享下如何找回丢失的commit的 打开项目所在位置,打开git bash,在gitBASH中输入 git f ...

  8. POJ:3259-Wormholes(最短路判断负环)

    Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 58153 Accepted: 21747 Descripti ...

  9. P2158 [SDOI2008]仪仗队 欧拉函数模板

    题目描述 作为体育委员,C君负责这次运动会仪仗队的训练.仪仗队是由学生组成的N * N的方阵,为了保证队伍在行进中整齐划一,C君会跟在仪仗队的左后方,根据其视线所及的学生人数来判断队伍是否整齐(如下图 ...

  10. Linux 批量删除文件后缀

    例子: [zengs@gene CASP9]$ lscasp9.ids T0526 T0538 T0550 T0562 T0574 T0586 T0598 T0610 T0622 T0634T0515 ...