博客
关于我
CodeForces 1484D Playlist 思维暴力
阅读量:502 次
发布时间:2019-03-07

本文共 1858 字,大约阅读时间需要 6 分钟。

题目链接

题意

给出一个数组,从1开始循环检查,如果gcd(a[i],a[i+1])=1(若i=n,那么比较a[n]和a[1]),那么就把a[i+1]移除。注意不能连续移除两个元素。问最终移除元素的数量和移除次序

思路

被前面题难度吓到了,这边直接带点思路打暴力就可以了。

看cf评论区说什么list和循环队列啥的,也没看明白,等出官方题解再说吧。

容易想到以下性质,在我们循环检查数组时,我们没有必要每次都对数组整个检查一遍,在处理完一遍后,能够产生新答案的位置只有上一次检查过程中产生了删除元素的位置。

我们用li数组记录每一个元素右边指向的元素,对于第i个元素,初始为i+1,之后可能会不断变化,比如我们把i右边的移除,那么li[i]则变成了li[li[i]],这样处理是非常节约时间的。

我们创建数组v,初始时存放1-n的全部下标,创建临时的t数组存放可能产生新答案的位置。对于满足条件的位置i,我们把i加入数组t,把li[i]打标记防止重复访问,更新li[i],更新答案。之后让v=t,循环直到v为空为止

教训/收获

  1. 别被吓到,想到就写,很多题没那么难,别摆烂
  2. c++11里可以用emplace_back()代替push_back(),他的插入效率更高,减少了不必要的构造,拷贝,析构等。但说实话vector平时都是基本类型居多,最多用个string,效率能高多少打个问号。

代码

#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define IOS ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);#define endl "\n"//#define int long long//#define double long doubleusing namespace std; typedef long long ll; const int maxn=200505; const int inf=0x3f3f3f3f; int n,m,k; int a[maxn]; int li[maxn]; bool vis[maxn]; vector
v,ans,t; struct custom_hash { static uint64_t splitmix64(uint64_t x) { x += 0x9e3779b97f4a7c15;x = (x ^ (x >> 30)) * 0xbf58476d1ce4e5b9;x = (x ^ (x >> 27)) * 0x94d049bb133111eb;return x ^ (x >> 31);}size_t operator()(uint64_t x) const { static const uint64_t FIXED_RANDOM = chrono::steady_clock::now().time_since_epoch().count();return splitmix64(x + FIXED_RANDOM);}}; signed main(){ IOS #ifndef ONLINE_JUDGE freopen("IO\\in.txt","r",stdin); freopen("IO\\out.txt","w",stdout); #endif int tn; cin>>tn; while(tn--){ cin>>n; ans.clear();v.clear(); for(int i=1;i<=n;i++){ cin>>a[i]; v.emplace_back(i); li[i]=i+1; vis[i]=0; } li[n]=1; while(v.size()){ t.clear(); for(auto i:v){ if(vis[i]) continue; if(__gcd(a[i],a[li[i]])==1){ ans.emplace_back(li[i]); vis[li[i]]=1; li[i]=li[li[i]]; t.emplace_back(i); } } v=t; } cout<

转载地址:http://dpnjz.baihongyu.com/

你可能感兴趣的文章
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>
mysql CPU使用率过高的一次处理经历
查看>>
Multisim中555定时器使用技巧
查看>>
MySQL CRUD 数据表基础操作实战
查看>>
multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
查看>>
mysql csv import meets charset
查看>>
multivariate_normal TypeError: ufunc ‘add‘ output (typecode ‘O‘) could not be coerced to provided……
查看>>
MySQL DBA 数据库优化策略
查看>>
multi_index_container
查看>>
mutiplemap 总结
查看>>
MySQL Error Handling in Stored Procedures---转载
查看>>
MVC 区域功能
查看>>
MySQL FEDERATED 提示
查看>>
mysql generic安装_MySQL 5.6 Generic Binary安装与配置_MySQL
查看>>
Mysql group by
查看>>
MySQL I 有福啦,窗口函数大大提高了取数的效率!
查看>>
mysql id自动增长 初始值 Mysql重置auto_increment初始值
查看>>
MySQL in 太多过慢的 3 种解决方案
查看>>
Mysql Innodb 锁机制
查看>>