博客
关于我
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/

你可能感兴趣的文章
MTCNN 人脸检测
查看>>
MyEcplise中SpringBoot怎样定制启动banner?
查看>>
MyPython
查看>>
MTD技术介绍
查看>>
MySQL
查看>>
MySQL
查看>>
mysql
查看>>
MTK Android 如何获取系统权限
查看>>
MySQL - 4种基本索引、聚簇索引和非聚索引、索引失效情况、SQL 优化
查看>>
MySQL - ERROR 1406
查看>>
mysql - 视图
查看>>
MySQL - 解读MySQL事务与锁机制
查看>>
MTTR、MTBF、MTTF的大白话理解
查看>>
mt_rand
查看>>
mysql -存储过程
查看>>
mysql /*! 50100 ... */ 条件编译
查看>>
mudbox卸载/完美解决安装失败/如何彻底卸载清除干净mudbox各种残留注册表和文件的方法...
查看>>
mysql 1264_关于mysql 出现 1264 Out of range value for column 错误的解决办法
查看>>
mysql 1593_Linux高可用(HA)之MySQL主从复制中出现1593错误码的低级错误
查看>>
mysql 5.6 修改端口_mysql5.6.24怎么修改端口号
查看>>