bzoj1257: [CQOI2007]余数之和 整除分块
题意:给出正整数n和k,计算j(n, k)=k mod 1 + k mod 2 + k mod 3 + … + k mod n的值其中k mod i表示k除以i的余数。例如j(5, 3)=3 mod 1 + 3 mod 2 + 3 mod 3 + 3 mod 4 + 3 mod 5=0+1+0+3+3=7
题解k%i=k-\(\left\lfloor\frac{k}{i}\right\rfloor\) \(*i\),然后\(\left\lfloor\frac{k}{i}\right\rfloor\)只会有\(\sqrt{n}\)个取值,所以可以通过整除分块来一次性算出相同因子的贡献
/**************************************************************
    Problem: 1257
    User: walfy
    Language: C++
    Result: Accepted
    Time:64 ms
    Memory:1288 kb
****************************************************************/
//#pragma comment(linker, "/stack:200000000")
//#pragma GCC optimize("Ofast,no-stack-protector")
//#pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,tune=native")
//#pragma GCC optimize("unroll-loops")
#include<bits/stdc++.h>
#define fi first
#define se second
#define mp make_pair
#define pb push_back
#define pi acos(-1.0)
#define ll long long
#define vi vector<int>
#define mod 1000003
#define C 0.5772156649
#define ls l,m,rt<<1
#define rs m+1,r,rt<<1|1
#define pil pair<int,ll>
#define pli pair<ll,int>
#define pii pair<int,int>
#define cd complex<double>
#define ull unsigned long long
#define base 1000000000000000000
#define fio ios::sync_with_stdio(false);cin.tie(0)
using namespace std;
const double eps=1e-6;
const int N=1000+10,maxn=1000000+10,inf=0x3f3f3f3f,INF=0x3f3f3f3f3f3f3f3f;
int main()
{
    ll n,k,ans=0;
    scanf("%lld%lld",&n,&k);
//    ll ans1=0;
//    for(ll i=1;i<=n;i++)ans1+=k%i;
//    printf("%lld\n",ans1);
    if(n>=k)
    {
        ans+=k*(n-k);
        n=k-1;
    }
    ans+=n*k;
    for(ll i=1,j;i<=n;i=j+1)
    {
        j=k/(k/i);
//        cout<<i<<" "<<j<<" "<<k/i<<endl;
        ll te=k/i;
        ans-=te*(min(n,j)+i)*(min(n,j)-i+1)/2;
        if(j>=n)break;
    }
    printf("%lld\n",ans);
    return 0;
}
/********************
********************/
bzoj1257: [CQOI2007]余数之和 整除分块的更多相关文章
- BZOJ1257: [CQOI2007]余数之和——整除分块
		题意 求 $\sum _{i=1}^n k \ mod \ i$($1\leq n,k\leq 10^9$). 分析 数据范围这么大 $O(n)$ 的复杂度也挺不住啊 根据取模的意义,$k \ mod ... 
- Bzoj 1257 [CQOI2007]余数之和 (整除分块)
		Bzoj 1257 [CQOI2007]余数之和 (整除分块) 题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1257 一道简单题. 题目 ... 
- bzoj1257[CQOI2007]余数之和(除法分块)
		1257: [CQOI2007]余数之和 Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 6117 Solved: 2949[Submit][Statu ... 
- BZOJ1257 [CQOI2007]余数之和 (数论分块)
		题意: 给定n, k,求$\displaystyle \sum_{i=1}^nk\;mod\;i$ n,k<=1e9 思路: 先转化为$\displaystyle \sum_{i=1}^n(k- ... 
- BZOJ1257 CQOI2007 余数之和 【数分块】
		BZOJ1257 CQOI2007 余数之和 Description 给出正整数n和k,计算j(n, k)=k mod 1 + k mod 2 + k mod 3 + - + k mod n的值 其中 ... 
- bzoj千题计划173:bzoj1257: [CQOI2007]余数之和sum
		http://www.lydsy.com/JudgeOnline/problem.php?id=1257 k%i=k-int(k/i)*i 除法分块,对于相同的k/i用等差序列求和来做 #includ ... 
- 51Nod 1225 余数之和 [整除分块]
		1225 余数之和 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 收藏 关注 F(n) = (n % 1) + (n % 2) + (n % 3) + ... ... 
- P2261 [CQOI2007]余数求和[整除分块]
		题目大意 给出正整数 n 和 k 计算 \(G(n, k)=k\ \bmod\ 1 + k\ \bmod\ 2 + k\ \bmod\ 3 + \cdots + k\ \bmod\ n\) 的值 其中 ... 
- [CQOI2007] 余数求和 - 整除分块
		\(\sum_{i=1}^n\;k\;mod\;i\) Solution \(\sum_{i=1}^n\;k\;mod\;i\\=\sum_{i=1}^n(k-i\lfloor{\frac{k}{i} ... 
随机推荐
- .NET中将中文符号转换成英文符号
			public static string ConvertToEn(string text) { const string s1 = ".:,?!.“”‘’"; const stri ... 
- MTA---smtp(25,postfix,sendmail),Pop3(110,Devocot),  MUA(foxmail) IMAP(server,client rsync)
			利用telnet进行SMTP的验证 =========先计算BASE64编码的用户名密码,认证登录需要用到=========== [crazywill@localhost crazywill]$ pe ... 
- 解决Uploadify 3.2上传控件加载导致的GET 404 Not Found问题
			http://www.uploadify.com/forum/#/discussion/7329/uploadify-v3-bug-unecessary-request-when-there-is-n ... 
- 迁移学习与fine-tuning有什么区别
			假设你要处理一个新数据集,让你做图片分类,这个数据集是关于Flowers的,问题是,数据集中flower的类别很少,数据集中的数据也不多,你发现从零开始训练CNN的效果很差,很容易过拟合,怎么办呢,于 ... 
- Openstack(十)部署nova服务(计算节点)
			在计算节点安装 10.1安装nova计算服务 # 阿里云源详见2.3配置 # yum install openstack-nova-compute 10.2配置nova计算服务 10.2.1配置nov ... 
- Openstack架构简介(一)
			1.1.1openstack介绍: openstack是(infrastructure as a service,基础设置即服务)IAAS架构的实现,OpenStack是一个由NASA(美国国家航空航 ... 
- Web安全大揭秘
			web安全大揭秘,通常会有那些web安全问题呢? 1,xss 2,sql注入 3,ddos攻击 
- java一些基本的方法
			一,Java中,next();和nextLine();有什么区别 举个例子,你就会明白了.如,你输入的一行:abc cde efg注意,其中abc和cde之间有空格,cde和efg之间也有空格这样,n ... 
- 问题:ORA-28000: the account is locked   用户锁住了。
			打开cmd: 执行 sqlplus /nolog 执行conn / as sysdba 执行 ALTER USER username ACCOUNT UNLOCK; 
- Linux下安装系统清理软件 BleachBit 1.4
			sudo add-apt-repository ppa:n-muench/programs-ppasudo apt-get updatesudo apt-get install bleachbit 
