Acwing-101-最高的牛(差分)
2024-09-04 00:38:31
链接:
https://www.acwing.com/problem/content/103/
题意:
有 N 头牛站成一行,被编队为1、2、3…N,每头牛的身高都为整数。
当且仅当两头牛中间的牛身高都比它们矮时,两头牛方可看到对方。
现在,我们只知道其中最高的牛是第 P 头,它的身高是 H ,剩余牛的身高未知。
但是,我们还知道这群牛之中存在着 M 对关系,每对关系都指明了某两头牛 A 和 B 可以相互看见。
求每头牛的身高的最大可能值是多少。
思路:
维护差分数组,对于a,b,Sub[a+1]-1, Sub[b]+1.即可.表示了a到b之间的值起码要少1.
处理重复,和相邻.
代码:
#include <bits/stdc++.h>
using namespace std;
const int MAXN = 1e4+10;
map<pair<int, int>, bool> mp;
int Sub[MAXN], Ori[MAXN];
int n, p, h, m;
int main()
{
scanf("%d%d%d%d", &n, &p, &h, &m);
int a, b;
for (int i = 1;i <= m;i++)
{
scanf("%d%d", &a, &b);
if (a > b)
swap(a, b);
if (a+1 == b)
continue;
if (mp[make_pair(a, b)])
continue;
mp[make_pair(a, b)] = true;
Sub[a+1] -= 1;
Sub[b] += 1;
}
Ori[p] = h;
for (int i = p;i >= 1;i--)
Ori[i-1] = Ori[i]-Sub[i];
for (int i = p;i <= n;i++)
Ori[i+1] = Ori[i]+Sub[i+1];
for (int i = 1;i <= n;i++)
printf("%d\n", Ori[i]);
return 0;
}
最新文章
- Transaction Save Point (SET XACT_ABORT { ON | OFF })
- RichEdit
- HttpContext为null new HttpContextWrapper(System.Web.HttpContext.Current)
- gerrit docker运行失败 chown: /var/gerrit/review_site: Permission denied 【已解决】
- 函数(def)
- 设置trace SQL
- Piggy-Bank(完全背包)
- 驴吃胡萝卜问题——牛客/FEI
- 00.pt-toolkit 目录
- Oracle数据库---用户与角色
- windows下如何通过git bash获取gitlab ssh公钥
- 利用NPOI导出数据到Execl
- [ASE][Daily Scrum]11.11
- 【Devops】【docker】【CI/CD】1.docker搭建Gitlab环境
- 构建高性能web之路------mysql读写分离实战(转)
- win32程序应用mfc库
- 单线程的redis为什么吞吐量可以这么大
- vue 一开始
- Canvas组件:画布,可以实现动画操作
- BZOJ 2073 [POI2004]PRZ(状压DP)
热门文章
- NOIp2018D1T2 货币系统【分析&;完全背包】
- icon.css
- [转帖]$PWD 和 $(pwd)
- Spark中分布式使用HanLP(1.7.0)分词示例
- SQLite基础-2.PyCharm+Database_Navigator
- Websocket 突破最大长连接
- 平衡树(Splay、fhq Treap)
- springboot2.X版本得@Transactional注解事务不回滚不起作用
- Collection接口的子接口——List接口
- C# 面向对象5 this关键字和析构函数