hehezhou 的鬼才神仙题解根本看不懂好吧。

首先判掉 \(n=1\)。

然后考虑最后一步,发现只用考虑怎样的左右端点可能见面。

左右和右左构成双射,算出总量减去自己配自己再除 \(2\) 即可。

于是考虑怎样的端点可以被生成。

容易发现结论:

\([l_1,r_1)[l_2,r_2)\dots[l_m,r_m)\) 可以合成 \([\min l,\max r)\) 内所有点。(左闭右开方便后面操作)

把所有 \(l,r\) 拉出来排序,考虑每一段区间内的点能够达到的

对于一个点,其左右必须各选至少一个点,从而将其“框住”。

考虑一个显然的事实:

如果对一个点,其左边端点数达到 \(4\) 且右边端点达到 \(4\)(或者,更准确的,除了最左最右端点及其对应端点外还分别有端点),则其可以和 \([\min l,\max r)\) 中所有端点配对!

这部分贡献直接 \(O(1)\) 统计,

剩下的部分,区间数量是 \(O(1)\) 的,且其中一半的端点数目是 \(O(1)\) 的,考虑暴力枚举具体使用的一对区间端点,

然后可以对最左、最右可行端点暴力移动枚举,显然移动也是 \(O(1)\) 的,

最后再取这些可行区间的并即可。

怎么取并呢?

对每次得到的可行端点对,更新左端点对应的最大右端点,

然后对其用单调性扫描一遍,再差分即可。

可能有点不大清楚,但估计代码还是看得懂的。

下面是核心代码。

std::pair<uint,uint>P[200005];
int main()
{
#ifdef MYEE
freopen("QAQ.in","r",stdin);
// freopen("QAQ.out","w",stdout);
#endif
uint t;scanf("%u",&t);
while(t--){
uint n;scanf("%u",&n);
for(uint i=0;i<n;i++)
scanf("%u%u",&P[i<<1].first,&P[i<<1|1].first),
P[i<<1].first--,P[i<<1].second=P[i<<1|1].second=i;
if(n==1){puts("1");continue;}
std::sort(P,P+(n<<1));
ullt ans=0;
for(uint i=1;i<n*2;i++)if(P[i].first!=P[i-1].first){
ullt wil=0;
if(i>=4&&n*2-i>=4)
wil=P[n*2-1].first-P[0].first-1;
else{
static uint R[200005];
for(uint j=0;j<n*2;j++)R[j]=j;
for(uint x=0;x<i;x++)for(uint y=i;y<n*2;y++){
uint l=0,r=n*2-1;
while(l<n*2&&(P[l].second==P[x].second||P[l].second==P[y].second))
l++;
if(l==n*2)continue;
while(~r&&(P[r].second==P[x].second||P[r].second==P[y].second))
r--;
_max(R[l],r);
}
for(uint j=1;j<n*2;j++)_max(R[j],R[j-1]);
for(uint j=0;j+1<n*2;j++)if(R[j]>j)
wil+=i==j+1?P[i].first-P[j].first-1:P[j+1].first-P[j].first;
}
ans+=wil*(P[i].first-P[i-1].first);
}
ans/=2;
printf("%llu\n",ans);
}
return 0;
}

gym104076H的更多相关文章

随机推荐

  1. windows搭建minikube环境学习Kubernates

    1.使用powershell下载minikube New-Item -Path 'c:\' -Name 'minikube' -ItemType Directory -Force Invoke-Web ...

  2. 时间序列分析 2.X 单位根检验

    单位根检验 (基于模型检验序列是否平稳) 趋势平稳序列 \(X_{t}=\beta_{0}+\beta_{1} t+Y_{t}\) \(Y_t\) 为平稳序列, 则称 \(X_t\) 为趋势平稳序列 ...

  3. SAP HANA:XS Job

    5.SAP HANA XS Job XS Job:定义重复执行的后台定期任务: 例如定时执行数据更新到Table的操作,需要使用到XS Job; SAP HANA XS Setting up Sche ...

  4. JS:获取元素属性

    元素上属性字段 const el = document.getElementById('documentLabel') console.log(el.clientWidth) // 可见区域宽 con ...

  5. (python笔记)python使用JS定位css元素

    from selenium import webdriver from selenium.webdriver.common.keys import Keys import time import da ...

  6. uniapp使用百度地图

    要使用第三方百度地图,首先要去百度地图官方申请一个密钥,之后引入百度地图的API文件,参考使用文档即可开发使用.而在uniapp中是没法直接引入百度地图API文件的,我们要结合uniapp中的web- ...

  7. 4-20mA换算为实际值公式

    Ov = [(Osh - Osl) * (Iv - Isl) / (Ish - Isl)] + Osl 实际工程量 = [((实际工程量)的高限 - (实际工程量)的低限)*(lv - 4) / (2 ...

  8. Metasploit渗透测试框架一

    Metasploit简介 Metasploit是一个渗透测试平台,使您能够查找,利用和验证漏洞.该平台还有Metasploit Pro. Metasploit是一个免费的.可下载的框架,本身自带数百已 ...

  9. Pytorch实战学习(四):加载数据集

    <PyTorch深度学习实践>完结合集_哔哩哔哩_bilibili Dataset & Dataloader 1.Dataset & Dataloader作用 ※Datas ...

  10. vue获取标签对象的方式

    我知道2种方式: 1.在标签内 使用 ref 属性定义对象名,使用this.$refs.[name] 调用 2.在标签内 使用 函数传递事件对象, 定义, <div @click="h ...