#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
#include <set>
using namespace std;
pair<long long, long long> p[300001];
long long x[300001];
pair<int, int> z[300001];
vector<int> E[300001];
int vis[300001];
void dfs(int u, int k)
{
vis[u] = k;
for (int i = 0; i < E[u].size(); i++)
{
int v = E[u][i];
if (!vis[v])
{
dfs(v, k);
}
}
}
int main()
{
int n;
scanf("%d", &n);
for (int i = 0; i < n; i++)
{
long long a, r;
scanf("%lld %lld", &a, &r);
p[i].first = a - r;
p[i].second = a + r;
x[i] = a;
}
for (int i = 0; i < n; i++)
{
int r = -1;
int l = n;
for (int j = 0; j < n; j++)
{
if (p[i].first <= x[j] && x[j] <= p[i].second)
{
l = min(l, j);
r = max(r, j);
}
}
z[i] = {l, r};
}
for (int i = 0; i < n; i++)
{
int r = -1;
int l = n;
for (int j = i + 1; j < n; j++)
{
int l0 = z[i].first;
int r0 = z[i].second;
int l1 = z[j].first;
int r1 = z[j].second;
if (l0 <= j && j <= r0)
{
E[i].push_back(j);
}
if (l1 <= i && i <= r1)
{
E[j].push_back(i);
}
}
}
set<int> S;
for (int i = 0; i < (1 << n); i++)
{
memset(vis, 0, n * 4);
for (int j = 0; j < n; j++)
{
if ((1 << j) & i)
{
if (!vis[j])
dfs(j, 1);
}
}
int mask = 0;
for (int j = 0; j < n; j++)
{
if (vis[j])
{
mask |= 1 << j;
}
}
S.insert(mask);
}
printf("%d", S.size());
return 0;
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 | #include <cstdio> #include <cstring> #include <algorithm> #include <vector> #include <set> using namespace std; pair<long long, long long> p[300001]; long long x[300001]; pair<int, int> z[300001]; vector<int> E[300001]; int vis[300001]; void dfs(int u, int k) { vis[u] = k; for (int i = 0; i < E[u].size(); i++) { int v = E[u][i]; if (!vis[v]) { dfs(v, k); } } } int main() { int n; scanf("%d", &n); for (int i = 0; i < n; i++) { long long a, r; scanf("%lld %lld", &a, &r); p[i].first = a - r; p[i].second = a + r; x[i] = a; } for (int i = 0; i < n; i++) { int r = -1; int l = n; for (int j = 0; j < n; j++) { if (p[i].first <= x[j] && x[j] <= p[i].second) { l = min(l, j); r = max(r, j); } } z[i] = {l, r}; } for (int i = 0; i < n; i++) { int r = -1; int l = n; for (int j = i + 1; j < n; j++) { int l0 = z[i].first; int r0 = z[i].second; int l1 = z[j].first; int r1 = z[j].second; if (l0 <= j && j <= r0) { E[i].push_back(j); } if (l1 <= i && i <= r1) { E[j].push_back(i); } } } set<int> S; for (int i = 0; i < (1 << n); i++) { memset(vis, 0, n * 4); for (int j = 0; j < n; j++) { if ((1 << j) & i) { if (!vis[j]) dfs(j, 1); } } int mask = 0; for (int j = 0; j < n; j++) { if (vis[j]) { mask |= 1 << j; } } S.insert(mask); } printf("%d", S.size()); return 0; } |
English