【2021牛客网赛前第二场普及模拟赛C数数】题解
题目大意
我们称一个集合 是好的,当且仅当把它们按照 降序排序后满足:
- 对于所有满足 的 ,有 或者 。
牛牛在二维平面上有一个 个点的集合。牛牛请你帮他算算有多少个非空子集 是好的。因为答案可能很大,你只需要告诉他答案对 取模后的结果。
我的思路
首先考虑暴力,设 为序列末尾分别为 的方案数,则
时间复杂度
考虑优化。
设 为以 结尾的数中前一个数为 的方案数,然后就可以套前缀和优化了。
时间复杂度
这题卡空间,需要用int,别开long long。
开始时 要离散化一次。
暴力code:
#include<bits/stdc++.h>
using namespace std;
#define int long long
inline int read(){int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;
ch=getchar();}while(ch>='0'&&ch<='9'){x=(x<<1)+
(x<<3)+(ch^48);ch=getchar();}return x*f;}
#define mo 1000000007
#define N 1510
struct node
{
int x,y;
}d[N];
int n, m, i, j, k, ans;
int minx, maxx;
int dp[N][N], a[N];
bool cmp(node x, node y)
{
return x.y>y.y;
}
signed main()
{
// freopen("tiaoshi.in", "r", stdin);
// freopen("tiaoshi.out", "w", stdout);
n=read();
for(i=1; i<=n; ++i)
{
d[i].x=read();
d[i].y=read();
}
sort(d+1, d+n+1, cmp);
for(i=1; i<=n; ++i) a[i]=d[i].x;
for(i=1; i<=n; ++i)
{
minx=maxx=0;
++ans;
for(j=1; j<i; ++j)
{
dp[i][j]=1; ++ans;
for(k=1; k<j; ++k)
if((a[i]>a[j]&&a[i]<a[k])||(a[i]>a[k]&&a[i]<a[j]))
{
ans=(ans+dp[j][k])%mo;
dp[i][j]=(dp[i][j]+dp[j][k])%mo;
}
}
}
printf("%lld", ans);
return 0;
}
code:
#include<bits/stdc++.h>
using namespace std;
// #define int long long
inline int read(){int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;
ch=getchar();}while(ch>='0'&&ch<='9'){x=(x<<1)+
(x<<3)+(ch^48);ch=getchar();}return x*f;}
#define mo 1000000007
#define N 6010
struct node
{
int x, y, z;
}d[N];
int n, m, i, j, k, ans;
int minx, maxx;
int dp[N], a[N];
int f[N][N];
bool cmp(node x, node y)
{
return x.y>y.y;
}
bool Cmp(node x, node y)
{
return x.z<y.z;
}
signed main()
{
// freopen("tiaoshi.in", "r", stdin);
// freopen("tiaoshi.out", "w", stdout);
n=read();
for(i=1; i<=n; ++i)
{
d[i].z=read();
d[i].y=read();
}
sort(d+1, d+n+1, Cmp);
d[1].x=k=1;
for(i=2; i<=n; ++i)
{
if(d[i].z!=d[i-1].z) ++k;
d[i].x=k;
// printf("%d ", d[i].x);
}
sort(d+1, d+n+1, cmp);
for(i=1; i<=n; ++i) a[i]=d[i].x;
// ans=n+n*(n-1)/2;
ans=n;
// printf("%lld ", ans); 1423
for(i=1; i<=n; ++i)
{
// printf("%lld\n", a[i]);
// minx=maxx=0;
memset(dp, 0, sizeof(dp));
// dp[0]=1;
for(j=1; j<i; ++j)
{
dp[a[j]]=(dp[a[j]]+1)%mo;
if(a[j]<a[i])
dp[a[j]]=(((dp[a[j]]+f[j][k]-f[j][a[i]])%mo)+mo) % mo;
if(a[j]>a[i])
dp[a[j]]=(dp[a[j]]+f[j][a[i]-1])%mo;
}
// sf[i][]
for(j=1; j<=k; ++j)
f[i][j]=(f[i][j-1]+dp[j])%mo;
// for(j=k; j>=0; --j)
// hf[i][j]=(hf[i][j+1]+dp[j])%mo;
// for(j=0; j<=k; ++j) printf("f[%lld][%lld]=%lld\n", i, j, dp[j]);
ans=(ans+f[i][k])%mo;
}
printf("%d", ans);
return 0;
}
本文来自博客园,作者:zhangtingxi,转载请注明原文链接:https://www.cnblogs.com/zhangtingxi/p/15558033.html
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战