首页 > 其他分享 >题解:【SWTR-8】15B03

题解:【SWTR-8】15B03

时间:2022-08-24 18:15:57浏览次数:130  
标签:15B03 奇数 题解 bmod SWTR 偶数 桌子 quad pts

题解:【SWTR-8】15B03

题目链接

前言

本篇题解大量配图!

作为一道非常好的有思维深度的题,必须写篇题解记录一下。

谨以此篇献给我的第一道构造题。

第一问(80 pts)

求需要撤去多少张桌子。

将问题转化成最多能放多少张桌子,然后用总数减去即可。

由于两张桌子不相邻需要保证对于 $ \forall (i,j) $ 满足 $ \vert i-i' \vert \le 1$ 且 $ \vert j-j' \vert \le 1$,所以当我们摆下一张桌子,下一张桌子一定跟这张桌子隔了一行或者一列。

当行(列)为偶数时,可以发现摆放的时候桌子的数量和比它少一行(列)的情况是相等的,为了计算方便可以直接去掉那一行(列),然后再下一问的时候加回来即可。

因此我们可以得出公式:
$$
Num_{can}=
\begin{cases}
(n/2+1) \times (m/2+1) \quad (n \bmod 2=1 \quad m \bmod 2=1) \
(n/2+1) \times ((m-1)/2+1) \quad (n \bmod 2=0 \quad m \bmod 2=1) \
((n-1)/2+1) \times (m/2+1) \quad (n \bmod 2=1 \quad m \bmod 2=0) \
((n-1)/2+1) \times ((m-1)/2+1) \quad (n \bmod 2=0 \quad m \bmod 2=0) \
\end{cases}
$$
$$
Ans=Num_{all} - Num_{can}=n \times m - Num_{can}
$$

$Code$

	bool p=1,q=1;
	cin>>n>>m;
	r=n*m;
	if(n%2==0) n--,p=0;
	if(m%2==0) m--,q=0;
	r-=(n/2+1)*(m/2+1);
	cout<<r<<" ";

第二问(20 pts)

性质一 (? pts)

这个性质虽然没有 sub 单独列出来,但是在测试点里面存在。

考虑只有一张桌子的情况,显然这时距离应该为 $0$。

$Code$

	if(n*m-r==1) {cout<<"0.000000000"<<endl; continue;}

性质二 n=1 (4 pts)

依然分奇偶讨论。
当 m 为奇数时,观察下图:
vkPgJS.png

可以发现,当摆放的桌子为偶数个时,我们将他们对半分开,左半部分的到最右一个端点为最远距离,右半部分的到最左一个端点为最远距离;而且可以发现,对称的两张桌子到最远端点的距离都相等。当摆放的桌子为奇数个时,最中间的这张桌子到两端距离自然相等,在多算上即可。

当 m 为偶数时,观察下图:
vAc4ET.png

绿色表示放在这两个地方都可以。

可以发现,无论摆放的桌子是奇数个还是偶数个,它们的摆放距离规律都跟奇数个类似。只不过当桌子越过中间的对称轴时,我们需要先再跳一个格子,然后再隔一个摆一张

因此我们可以将这个长条折半,只算一半的距离最后乘二即可。

$Code$

//q是上面判断m奇偶性的
if(n==1&&(q)) 
{
	for(int i=0;i<(m+1)/2/2;i++)
		ans+=(m-2*i);
	ans*=2;
	if((m/2)%2==0) ans=ans+m-(m-1)/2;
	cout<<fixed<<setprecision(9)<<ans<<endl; 
}
else if(n==1&&(!q)) 
{
	for(int i=0;i<=m/4;i++)
		ans+=(m-2*i);
	ans*=2;
	if((m/2)%2==1) ans=ans+(m+2)/2;
	cout<<fixed<<setprecision(9)<<ans<<endl; 
}

性质三 n 和 m 都是奇数 (3 pts)

可以发现,这个性质把 n 从 1 延伸到了更多行,上一个性质中是 m 为偶数的情况较难处理,而这个性质简单在 m 只会是奇数。

我们在上个性质中发现了行为 1 时列的性质,那行会不会具有同样的性质呢?

观察下图:
vAgdz9.png

蓝色的箭头是选这个距离也可以,是一样长的。

推荐再配合题目样例一中的图共同食用。

可以发现对于任意一张桌子,它们的最远距离是到和它们相对的角上去。

无独有偶,无论行还是列,关于行、列中线对称的桌子最远距离都是相等的。比如上图中,从行来看,$(1,1)$ 和 $(5,1)$,$(1,3)$ 和 $(5,3)$,$(1,5)$ 和 $(5,5)$ 是对称的;从列来看,$(1,1)$ 和 $(1,5)$,$(3,1)$ 和 $(3,5)$,$(5,1)$ 和 $(5,5)$ 是对称的。

因此我们可以把这个方形分成四等份,只算其中一份就行。

无特殊性质 (20 pts)

既然找到了行列都为奇数的规律,不妨大胆猜想,偶数的时候行列的规律也是相同的,这当然是正确的。

计算的时候,暴力计算每一张桌子的最远距离,当跨过行或列的对称轴是将它统一对称过来,特殊的,当行或列为偶数时,跨过对称轴行或列还要额外加一。

时间复杂度 $O(n^2)$。

比赛没有写出只算四分之一个矩形的程序,喜提最裂解,但是我这个方法比较好理解,也比较好写,最后奉上比赛时的代码。

$Code$

#include<bits/stdc++.h>
#define ll long long
using namespace std;
ll s,t,n,m,r;
int main()
{
	std::ios::sync_with_stdio(false);
	cin.tie(0),cout.tie(0);
	cin>>s>>t;
	for(int i=1;i<=t;i++)
	{
		bool p=1,q=1;
		cin>>n>>m;
		r=n*m;
		if(n%2==0) n--,p=0;
		if(m%2==0) m--,q=0;
		r-=(n/2+1)*(m/2+1);
		cout<<r<<" ";		
		if(p==0) n++;
		if(q==0) m++;
		if(n*m-r==1) {cout<<"0.000000000"<<endl; continue;}
		long double ans=0.0;
		long long k=1,j=1;
		p=1,q=1;
		for(k=1;k<=n;k+=2)
		{
			q=1;
			for(j=1;j<=m;j+=2)
			{
				if(m%2==0&&j>(m/2)&&(q)) j++,q=0;
				long long x,y;
				if(k<=(n+1)/2) x=k;
				else x=n-k+1;
				if(j<=(m+1)/2) y=j;
				else y=m-j+1;
//				cout<<x<<" "<<y<<"     ";
				ans+=sqrtl(((long double)((n-x)*(n-x))+((long double)((m-y)*(m-y)))));
//				cout<<" "<<ans<<"      ";
			}
			if(n%2==0&&k+2>=(n/2)&&(p)) k++,p=0;
		}
		cout<<fixed<<setprecision(9)<<ans<<endl; 
	}
	return (0-0);  
}

标签:15B03,奇数,题解,bmod,SWTR,偶数,桌子,quad,pts
From: https://www.cnblogs.com/LittleTwoawa/p/16621104.html

相关文章

  • 题解:「GLR-R3」雨水
    题解:「GLR-R3」雨水题目链接前言先吐槽一下,这个英文是真的坑。constintMAXN=712;//Setarightvalueaccordingtoyoursolution.为啥不能直接把数组下标设为......
  • 题解:【TJOI2012】防御
    【TJOI2012】防御题目链接小清新数据结构题,题解区为啥清一色两棵线段树。考虑分块,维护两个数组:$tag$和$minx$分别记录整块的累计伤害和当前护盾最小值。当发现有护盾......
  • 题解:【THUSCH2017】 大魔法师
    【THUSCH2017】大魔法师题目链接前言线段树和矩阵乘法的板子拼接题,这个题题目本身思维难度不大,但是可以给我们提供许多平时写代码的底层优化技巧。题目思路首先回到......
  • 题解:【POI2001】Goldmine
    【POI2001】Goldmine题目链接扫描线板子题,本质上这个题跟窗口的星星是一样的,只不过把权值$k$都换成$1$就行。但是需要注意的是这句话:(若矿石位于这块地的边缘,我们同......
  • 数的划分 题解
    \(0.\)写在前面1.3【例题1】数的划分-TuringEDUP2706数的划分-TopsCoding这题可以有两种写法:(至少两种)深搜计数\(\text{DP}\)接下来将会依次讲解\(1.\)......
  • 题解:【WC2005】双面棋盘
    【WC2005】双面棋盘题目链接这天做双面棋盘这道题,发现题解里面大多都是LCT,对于线段树套并查集的写法思路讲评很少而且不大清晰,因此有了这一篇题解。维护联通块的数量,......
  • has been blocked by CORS policy跨域问题解决
    title:hasbeenblockedbyCORSpolicy跨域问题解决我们在前端调用接口时,浏览器有时候会报错:XXXXformXXXXXhasbeenblockedbyCORSpolicy:No'Access-Control-......
  • CF1715F Crop Squares 题解
    CF1715FCropSquaressolution有一个\(n\timesm\)的长方形,四个角的坐标分别为$(0,0)$,$(0,m)$,$(n,0)$,$(n,m)$。在长方形里面有一个\(1\time......
  • CF838D题解
    很厉害的题。考虑将原本的座位串成一个环,然后加一个节点在\(1\)的前面\(n\)的后面。原问题等价为新节点不被座到的方案数。容易发现所有节点被座到和不被座到的方案......
  • 关于npm ERR! ERESOLVE could not resolve 问题解决
    1、问题描述从代码仓库拉取代码到本地,执行npminstall命令安装项目依赖,提示如下图错误  问题出现的原因由于npm版本问题,npm不同版本库之间命令不兼容。解决办法:执......