HDU 5726 GCD
来源:互联网 发布:web q前端开发json 编辑:程序博客网 时间:2024/04/28 22:14
http://acm.split.hdu.edu.cn/showproblem.php?pid=5726
数字越多GCD后的值越小,而且只能继续变小,利用这一原则可以用map储存数值一旦数值变换就更改段的起点。再储存下每个值的个数。
#include<iostream>#include <cstring>#include <cstdio>#include <vector>#include <map>using namespace std;int n,num[100005];vector<pair<int,int> >gcd[100005];map<int,long long>Ans;int GCD(int x, int y){ return y ? GCD(y, x % y) : x;}int main(){ int T,Test=0; scanf("%d",&T); while(T--) { scanf("%d",&n); for(int i=1;i<=n;i++){ scanf("%d",&num[i]); } int last; Ans.clear(); for(int k=1;k<=n;k++){ last=0; for(int j=0;j<gcd[k-1].size();j++){ int u=gcd[k-1][j].first,v=gcd[k-1][j].second; u=GCD(u,num[k]); if(u==last){ continue; } last=u; gcd[k].push_back(make_pair(u,v)); } if(num[k]!=last){ gcd[k].push_back(make_pair(num[k],k)); } for(int i=0;i<gcd[k].size();i++){ Ans[gcd[k][i].first]+=(i!=gcd[k].size()-1?gcd[k][i+1].second:k+1)-gcd[k][i].second; } } int m; scanf("%d",&m); printf("Case #%d:\n", ++Test); for(int i=0,u,v,k;i<m;i++){ scanf("%d%d",&u,&v); for(k=0;k<gcd[v].size();k++){ if(u<gcd[v][k].second){ break; } } printf("%d %I64d\n",gcd[v][k-1].first,Ans[gcd[v][k-1].first]); } for (int i = 0; i <= n; ++i) { gcd[i].clear(); } } return 0;}
0 0
- HDU 5726 GCD
- 多校&&HDU 5726 GCD
- HDU 5726 GCD RMQ
- HDU-5726 GCD
- HDU 5726 GCD
- HDU 5726-GCD
- HDU 5726 GCD
- HDU-5726 GCD
- HDU 5726 GCD
- hdu 5726(区间gcd)
- HDU 5726 GCD
- HDU 5726 GCD
- HDU 5726 - GCD
- HDU 5726 GCD
- HDU 5726 GCD 倍增
- hdu 5726 GCD (区间gcd-RMQ)
- HDU 5726 GCD [RMQ+二分]
- HDU 5726 GCD(RMQ + 二分)
- android_关于handler笔记
- wordpress 的 wp2sinablog插件
- ImageNet Classification with Deep Convolutional Neural Networks
- python查看是32位还是64位版本
- 检查列表是否为空的最好方法
- HDU 5726 GCD
- B:LINUX解析UBOOT传入参数的原理
- Sublime text2 自动补齐功能开启(jedi+sublimecodeintel)
- 让Android Support V4中的SwipeRefreshLayout支持上拉加载更多
- 392. Is Subsequence
- khmer显示--改进版本
- gulp学习
- Python进阶
- 一个简单至极的PHP缓存类代码