And Reachability

题面翻译

题目描述

Toad Pimple 有一个整数数组 \(a_1,\dots,a_n\)。

当 \(x < y\) 且存在 \(x = p_1 < \dots < p_k = y\) 的数列 \(p\) 满足 \(a_{p_i} \& a_{p_{i+1}} > 0\) 时,我们称 \(y\) 是可从 \(x\) 到达的。

其中 \(\&\) 表示按位与运算。

现在给出 \(q\) 组下标,请检查它们可否到达。

输入输出格式

输入格式:

第一行,两个整数 \(n,q\;(2 \le n \le 300\,000,1 \le q \le 300\,000)\),表示数组的长度和查询的个数。

第二行,\(n\) 个整数 \(a_1,\dots,a_n\;(0 \le a_i \le 300\;000)\),表示给定的数组。

接下来 \(q\) 行中,第 \(i\) 行两个整数 \(x_i,y_i\;(1 \le x_i < y_i \le n)\),表示你需要检查 \(y_i\) 是否可从 \(x_i\) 到达。

输出格式:

输出 \(q\) 行。

对于每个询问,如果可到达,输出「Shi」,否则输出「Fou」。

说明

第一个样例中,\(a_3 = 0\),与其按位与结果总是 \(0\),所以不可到达。

\(a_2 \& a_4 > 0\),所以 \(4\) 可从 \(2\) 到达。

并且从 \(1\) 到达 \(4\) 中,\(p = [1,2,4]\)。

题目描述

Toad Pimple has an array of integers $ a_1, a_2, \ldots, a_n $ .

We say that $ y $ is reachable from $ x $ if $ x<y $ and there exists an integer array $ p $ such that $ x = p_1 < p_2 < \ldots < p_k=y $ , and $ a_{p_i}, &, a_{p_{i+1}} > 0 $ for all integers $ i $ such that $ 1 \leq i < k $ .

Here $ & $ denotes the bitwise AND operation.

You are given $ q $ pairs of indices, check reachability for each of them.

输入格式

The first line contains two integers $ n $ and $ q $ ( $ 2 \leq n \leq 300,000 $ , $ 1 \leq q \leq 300,000 $ ) — the number of integers in the array and the number of queries you need to answer.

The second line contains $ n $ space-separated integers $ a_1, a_2, \ldots, a_n $ ( $ 0 \leq a_i \leq 300,000 $ ) — the given array.

The next $ q $ lines contain two integers each. The $ i $ -th of them contains two space-separated integers $ x_i $ and $ y_i $ ( $ 1 \leq x_i < y_i \leq n $ ). You need to check if $ y_i $ is reachable from $ x_i $ .

输出格式

Output $ q $ lines. In the $ i $ -th of them print "Shi" if $ y_i $ is reachable from $ x_i $ , otherwise, print "Fou".

样例 #1

样例输入 #1

5 3
1 3 0 2 1
1 3
2 4
1 4

样例输出 #1

Fou
Shi
Shi

提示

In the first example, $ a_3 = 0 $ . You can't reach it, because AND with it is always zero. $ a_2, &, a_4 > 0 $ , so $ 4 $ is reachable from $ 2 $ , and to go from $ 1 $ to $ 4 $ you can use $ p = [1, 2, 4] $ .

有关位运算,按位考虑。

如果改 \(x\) 的时候出现了某一个 \(y\) 也有的位,那就可以直接跳到 \(y\) 了。

那么定义 \(d_{i,j}\) 为第 \(i\) 个数,要跳到一个拥有第 \(j\) 位的数,最前是跳到哪一个。

然后倒着枚举 \(i\),找到一个这个数跳到拥有第 \(k\) 位的到哪里,然后转移 d 数组。

#include<bits/stdc++.h>
using namespace std;
const int N=3e5+5;
int read()
{
int s=0;
char ch=getchar();
while(ch<'0'||ch>'9')
ch=getchar();
while(ch>='0'&&ch<='9')
s=s*10+ch-48,ch=getchar();
return s;
}
int n,q,a[N],mx,nx[20][20],ds[N][20];
int main()
{
// freopen("and.in","r",stdin);
// freopen("and.out","w",stdout);
scanf("%d%d",&n,&q);
for(int i=1;i<=n;i++)
a[i]=read();
for(int i=0;i<=18;i++)
for(int j=0;j<=18;j++)
nx[i][j]=n+1;
for(int j=0;j<=18;j++)
ds[n+1][j]=n+1;
for(int i=n;i;i--)
{
for(int j=0;j<=18;j++)
{
if(a[i]>>j&1)
ds[i][j]=i;
else
ds[i][j]=n+1;
}
for(int j=0;j<=18;j++)
for(int k=0;k<=18;k++)
if((a[i]>>j&1)&&(a[i]>>k&1))
nx[j][k]=i;
for(int j=0;j<=18;j++)
{
int mn=n+1;
for(int k=0;k<=18;k++)
if(a[i]>>k&1)
mn=min(mn,nx[j][k]);
for(int k=0;k<=18;k++)
ds[i][k]=min(ds[i][k],ds[mn][k]);
}
// for(int j=0;j<=7;j++)
// printf("%d ",ds[i][j]);
// puts("");
}
while(q--)
{
int fl=0,x=read(),y=read();
for(int i=0;i<=18;i++)
if(ds[x][i]<=y&&(a[y]>>i&1))
fl=1,puts("Shi"),i=18;
if(!fl)
puts("Fou");
}
}

[CF1168C] And Reachability的更多相关文章

  1. CF1168C And Reachability 【构造,dp】

    题目链接:洛谷 题目描述:给出$n$个数$a_i$,若$i<j$且$a_i & a_j>0$,则$i$到$j$连一条有向边,$q$次询问,询问从$l$开始是否能到达$r$. 数据范 ...

  2. CF1168C And Reachability(DP)

    首先定义 $g[i][j]$ 表示 $i$ 前面(不包括 $i$)第一个第 $j$ 位是 $1$ 的数的位置.可以随便转移. 再定义 $f[i][j]$ 表示 $i$ 前面(包括 $i$)第一个第 $ ...

  3. iOS网络4——Reachability检测网络状态

    一.整体介绍 前面已经介绍了网络访问的NSURLSession.NSURLConnection,还有网页加载有关的webview,基本满足通常的网络相关的开发. 其实在网络开发中还有比较常用的就是网络 ...

  4. 通读AFN③--HTTPS访问控制(AFSecurityPolicy),Reachability(AFNetworkReachabilityManager)

    这一篇主要介绍使用AFN如何访问HTTPS网站以及这些做法的实现原理,还有介绍AFN的网络状态监测部分AFNetworkReachabilityManager,这个模块会和苹果官方推荐的Reachab ...

  5. 3-HOP: A High-Compression Indexing Scheme for Reachability Query

    title: 3-HOP: A High-Compression Indexing Scheme for Reachability Query venue: SIGMOD'09 author: Ruo ...

  6. IOS开发之网络编程开源类 Reachability应用

    先看Reachability.h发现 #import <Foundation/Foundation.h> #import <SystemConfiguration/SystemCon ...

  7. iOS中使用 Reachability 检测网络

    iOS中使用 Reachability 检测网络 内容提示:下提供离线模式(Evernote).那么你会使用到Reachability来实现网络检测.   写本文的目的 了解Reachability都 ...

  8. Reachability(判断网络是否连接)

    类似于一个网络状况的探针. [[NSNotificationCenter defaultCenter] addObserver: self selector: @selector(reachabili ...

  9. iOS开发 利用Reachability判断网络环境

    导入头文件:#import "Reachability.h" 然后将 SystemConfiguration.framework 添加进工程: 1.检查当前的网络状态(wifi.W ...

  10. IOS 网络浅析(一 网络监测~Reachability)

    网络监测应用于各种需要连接网络的app设计,由于现在开发的app几乎都用到网络,因此,网络监测也成为了较为重点的知识,下面我给大家简单讲解一下网络监测的实际应用,依旧会有代码哦. 想要实现网络监测,可 ...

随机推荐

  1. Linux文件管理知识查找文件(第二篇)

    Linux文件管理知识:查找文件(第二篇) 上篇文章详细介绍了linux系统中查找文件的工具或者命令程序locate和find命令的基本操作.那么,今天这篇文章紧接着查找文件相关操作内容介绍. Fin ...

  2. 青语言V1.0正式发布

    大家好,距离6月1日青语言发布第一个版本已经过去了三个月,而今我们按计划发布青语言的1.0版本. 青语言主页:https://qingyuyan.cn V1发布宣传视频:https://www.bil ...

  3. API数据接口的应用步骤

    API(Application Programming Interface)是现代软件应用程序开发中的一项重要技术,它允许不同的应用程序之间进行通信和数据交换.API接口通过提供统一的访问点,使得应用 ...

  4. 使用 OpenTelemetry 构建 .NET 应用可观测性(2):OpenTelemetry 项目简介

    前世今生 OpenTracing OpenTracing 项目启动于 2016 年,旨在提供一套分布式追踪标准,以便开发人员可以更轻松地实现分布式追踪. OpenTracing 定义了一套 Traci ...

  5. 聊透 GPU 通信技术——GPU Direct、NVLink、RDMA 审核中

    最近人工智能大火,AI 应用所涉及的技术能力包括语音.图像.视频.NLP 等多方面,而这些都需要强大的计算资源支持.AI 技术对算力的需求是非常庞大的,虽然 GPU 的计算能力在持续提升,但是对于 A ...

  6. LVGL双向链表学习笔记

    LVGL双向链表学习笔记 1.LVGL链表数据类型分析 对于LVGL双向链表的使用,我们需要关注lv_ll.h和lv_ll.c两个文件,其中lv_ll.h里面包含了链表结构类型定义,以及相关API的声 ...

  7. C++在HotSpot VM中一种巧妙的内存管理方式

    在HotSpot VM中定义了一个Relocation类及相关的子类,可以通过这些类操作不同的重定位数据,如在CodeCache中读写这些数据.这些类需要的内存很小,但是不同的类需要的内存大小又不一样 ...

  8. P9140 [THUPC 2023 初赛] 背包

    prologue 这很难评(调了我 1h,我都想紫砂了. 还是典型得不重构就看不见系列. analysis 如果我们还是一个正常人,那么我们大体上是能看到题目的加粗字,这个格式很明显符合我们的同余最短 ...

  9. linux bond nmcli命令

    基本命令: nmcli connection show 显示所有连接nmcli connection show --active 显示所有活动的连接状态nmcli connection show &q ...

  10. js排序算法--冒泡排序

    <!DOCTYPE html> <html> <head> <title></title> </head> <body&g ...