测试地址:函数
做法: 本题需要用到思维。
如果在
x
x
x坐标为负无穷时,把函数从下到上编号为
1
1
1~
n
n
n,那么在向右扫时,一旦遇到一个交点,就表示交的这两个函数上下位置进行交换。因为每两个函数间有且仅有一个交点,且不会有三个函数共点,因此这些交换是先后进行的,且一定是发生在下面的函数编号比上面的函数小时,那么最后在
x
x
x坐标为正无穷时必定会换为从下到上
n
n
n ~
1
1
1的形式。于是现在要求第
k
k
k层的段数,实际上就是在交换的过程中,从下到上第
k
k
k个位置上编号的最小变动次数
+
1
+1
+1。
根据推理,一个位置上编号最小的变动次数为
min
(
2
k
−
1
,
2
(
n
−
k
+
1
)
−
1
)
\min(2k-1,2(n-k+1)-1)
min(2k−1,2(n−k+1)−1)。首先这两种情况是对称的,因此我们只考虑
k
≤
(
n
−
k
+
1
)
k\le (n-k+1)
k≤(n−k+1)的情况,我们肯定考虑把右边最大的
k
k
k个数挪到左边去,那么最小的交换次数就是,前
k
−
1
k-1
k−1个数因为要经过那个位置,所以都产生
2
2
2的贡献,而最后一个数正好放在那个位置上,因此只产生
1
1
1的贡献,总贡献就是
2
k
−
1
2k-1
2k−1了,那么另一种情况只要对称考虑即可。因此答案为
min
(
2
k
,
2
(
n
−
k
+
1
)
)
\min(2k,2(n-k+1))
min(2k,2(n−k+1)),
n
=
k
=
1
n=k=1
n=k=1时需要特判,这样我们就非常简单地解决了这一题。
以下是本人代码:
#include <bits/stdc++.h>
using namespace std;
int n,k;
int main()
{
scanf("%d%d",&n,&k);
if (n==1) printf("1");
else printf("%d",min(2*k,2*(n-k+1)));
return 0;
}
本文介绍了一种利用函数交点特性解决数学问题的方法。通过分析函数在坐标轴上的相对位置变化,推导出了求解特定层段数的公式。在正无穷和负无穷坐标处,函数编号的变化遵循特定规律,由此可以计算出任意层段数的最小变动次数。代码实现简洁高效,适用于解决类似数学问题。
1014

被折叠的 条评论
为什么被折叠?



