博客
关于我
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-开启慢查询&所有操作记录日志
查看>>
MySQL-数据目录
查看>>
MySQL-数据页的结构
查看>>
MySQL-架构篇
查看>>
MySQL-索引的分类(聚簇索引、二级索引、联合索引)
查看>>
Mysql-触发器及创建触发器失败原因
查看>>
MySQL-连接
查看>>
mysql-递归查询(二)
查看>>
MySQL5.1安装
查看>>
mysql5.5和5.6版本间的坑
查看>>
mysql5.5最简安装教程
查看>>
mysql5.6 TIME,DATETIME,TIMESTAMP
查看>>
mysql5.6.21重置数据库的root密码
查看>>
Mysql5.6主从复制-基于binlog
查看>>
MySQL5.6忘记root密码(win平台)
查看>>
MySQL5.6的Linux安装shell脚本之二进制安装(一)
查看>>
MySQL5.6的zip包安装教程
查看>>
mysql5.7 for windows_MySQL 5.7 for Windows 解压缩版配置安装
查看>>
Webpack 基本环境搭建
查看>>
mysql5.7 安装版 表不能输入汉字解决方案
查看>>