最长对称子串 || 区间dp || 马拉车

dp[i][j]表示区间[i, j]是否为回文串,若是则为1,不是则为0。

边界条件:

1. 区间长度为1,dp为1。(奇数个字符递推的起始情况)

2. 区间长度为2,且两个字符相同,则dp为1。(偶数个字符递推的起始情况)

3. 右边界不超过n。

转移:

当区间长度大于2时,若dp[l+1][r-1] == 1 && s[l] == s[r],那么dp[l][r] = 1;

第一维遍历区间长度,第二维遍历左端点。通过这两维可以确定区间右端点的位置,若满足条件则转移。由于转移是从小区间到大区间,而最外层循环是从小区间开始,所以递推成立。

#include <bits/stdc++.h>
using namespace std;
typedef long long ll; bool dp[1111][1111];
char s[1111];
int main()
{
scanf("%[^\n]", s + 1);//读入一行,gets可能有的oj不支持
int n = strlen(s + 1), r;
int ans = 1;
for(int i = 1; i <= n; ++i) {
for (int l = 1; l <= n; ++l) {
r = l + i - 1;
if (r > n) break;
if (i == 1) dp[l][l] = 1;
else if (i == 2 && s[l] == s[r])
{
dp[l][r] = 1;
ans = max(ans, 2);
}
else if (i > 2 && s[l] == s[r] && dp[l + 1][r - 1] == 1)
{
dp[l][r] = 1;
ans = max(ans, i);
}
}
}
cout << ans << endl;
return 0;
}

列车调度 || 模拟&set使用

遍历,单调递减的一个连续序列一定属于一个队列,若不是,则将该元素与各个队列最小的元素进行比较,找到大于它的最小的那个元素。

我们用set维护各个队列最小的元素集合,而set的大小则为当前需要队列的个数。

#include <bits/stdc++.h>
using namespace std; set<int> s;
int n; int main()
{
scanf("%d", &n);
int mx = 0, x;
for(int i = 0; i < n; i++)
{
scanf("%d", &x);
auto it = s.lower_bound(x);
if(it == s.end()) s.insert(x);
else
{
s.erase(it);
s.insert(x);
}
mx = max(mx, (int)s.size());
}
printf("%d\n", mx);
}

红色警报 || dfs&连通块

如何判断失去一个城市,国家的连通性发生变化?当然是连通块的个数发生变化。

那么考虑连通块的数目将如何变化呢?可能不变,可能变多(注意,可能不止多1),可能变少(由于有一个连通块为单独的一个点,删除这个点后连通块数目-1)。

数据范围很小,那就暴力呀!每次删除一个城市,计算连通块数目,若变多,则说明国家的连通性发生了变化,反之不变。

vis数组表示每次dfs时是否已经访问过该节点,mark数组用于标记已经失去的城市,它们已经无法访问。

#include <cstdio>
#include <iostream>
#include <vector>
using namespace std;
typedef long long ll; vector<int> G[555];
bool vis[555];
bool mark[555]; int cnt; void dfs(int s)
{
vis[s] = 1;//放在这里,而不是下面那个if下面,否则可能从s来,又回到了s
for(int i = 0; i < G[s].size(); ++i)
{
if(!vis[G[s][i]] && !mark[G[s][i]])
{
dfs(G[s][i]);
}
}
} int main()
{
int n, m, x, y, r, s;
cin >> n >> m;
for(int i = 1; i <= m; ++i)
{
scanf("%d %d", &x, &y);
if(x == y) continue;
G[x].push_back(y);
G[y].push_back(x);
}
cin >> r;
for(int j = 0; j < n; ++j)
{
if(!vis[j])
{
dfs(j);
++cnt;
}
}
int pr = cnt;
for(int i = 1; i <= r; ++i)
{
cnt = 0;
fill(vis, vis + n, 0);
scanf("%d", &s);
mark[s] = 1;
for(int j = 0; j < n; ++j)
{
if(!vis[j] && !mark[j])
{
dfs(j);
++cnt;
}
}
if(cnt >= pr + 1)//不一定只多1呀!
cout << "Red Alert: City " << s << " is lost!" << endl;
else cout << "City " << s << " is lost." << endl;
if(i == n) cout << "Game Over." << endl;
pr = cnt;
}
}

p.s. 连通块个数不仅可以dfs,还可以用并查集实现。

这里dfs的方法是最外层大循环一次dfs每个点,若已经访问过,就不dfs,若没有,则dfs,并且连通块数cnt++;

PTA天梯赛校内模拟的更多相关文章

  1. PTA天梯赛训练题L1-064:估值一亿的AI核心代码(字符串模拟)

    Update:smz说regex秒过Orz,yzd记在这里了. 听说今年天梯赛有个烦人的模拟,我便被队友逼着试做一下……一发15,二发20.记一记,要不然枉费我写这么久…… 自己还是代码能力太菜了,校 ...

  2. 『ACM C++』 PTA 天梯赛练习集L1 | 001-006

    应师兄要求,在打三月底天梯赛之前要把PTA上面的练习集刷完,所以后面的时间就献给PTA啦~ 后面每天刷的题都会把答案代码贡献出来,如果有好的思路想法也会分享一下~ 欢迎大佬提供更好的高效率算法鸭~ - ...

  3. PTA 天梯赛 L1

    L1-002 打印沙漏 细节:就是在  (i>j&&i+j<r+1) 这个区间里才有空格,然后就是 for 循环   for(r=1; ;r+=2)  条件不满足之后还会再 ...

  4. 『ACM C++』 PTA 天梯赛练习集L1 | 052-053

    今日刷题,水题水题 ------------------------------------------------L1-052------------------------------------ ...

  5. 『ACM C++』 PTA 天梯赛练习集L1 | 048-49

    今日刷题048-049 ------------------------------------------------L1-048---------------------------------- ...

  6. 『ACM C++』 PTA 天梯赛练习集L1 | 040-41

    近期安排 校赛3.23天梯赛3.30华工校赛 4.21省赛 5.12 ------------------------------------------------L1-040----------- ...

  7. 【PTA 天梯赛】L1-046 整除光棍(除法模拟)

    这里所谓的“光棍”,并不是指单身汪啦~ 说的是全部由1组成的数字,比如1.11.111.1111等.传说任何一个光棍都能被一个不以5结尾的奇数整除.比如,111111就可以被13整除. 现在,你的程序 ...

  8. 【PTA 天梯赛】L2-028 秀恩爱分得快(模拟)

    古人云:秀恩爱,分得快. 互联网上每天都有大量人发布大量照片,我们通过分析这些照片,可以分析人与人之间的亲密度.如果一张照片上出现了 K 个人,这些人两两间的亲密度就被定义为 1/K.任意两个人如果同 ...

  9. 【PTA 天梯赛训练】QQ帐户的申请与登陆(散列+set模拟)

    实现QQ新帐户申请和老帐户登陆的简化版功能.最大挑战是:据说现在的QQ号码已经有10位数了. 输入格式: 输入首先给出一个正整数N(≤10^5),随后给出N行指令.每行指令的格式为:“命令符(空格)Q ...

随机推荐

  1. 基于flask的python注册到eureka

    Eureka架构中的三个核心角色: 服务注册中心 Eureka的服务端应用,提供服务注册和发现功能,就是刚刚我们建立的eureka-demo 服务提供者 提供服务的应用,可以是SpringBoot应用 ...

  2. TCP/IP 基础知识

    我把自己以往的文章汇总成为了 Github ,欢迎各位大佬 star https://github.com/crisxuan/bestJavaer 已提交此篇文章 要说我们接触计算机网络最多的协议,那 ...

  3. week01-绪论作业

    一.有理数的抽象数据模型 ADT Rational { 数据对象: D={e1,e2|e1,e2属于ElemType类型}//ElemType为自定义的整数集合类型 数据关系: R={<e1,e ...

  4. 查看并配置JAVA_HOME

    转载自https://blog.csdn.net/weixin_41713592/article/details/79941418which java [root@host2 hadoop-1.1.2 ...

  5. 白话科普系列——双十一,竟然是一场有“预谋”的DDoS攻击?

    随著互联网与信息技术的发展,所有人都在享受互联网带来的舒适和便利.如今,无论是个人社交行为,还是商业活动都早已离不开互联网. 但是,网络空间在创造机遇的同时,也带来了威胁.随着企业价值.知名度的提高. ...

  6. 记一次使用idea插件CamelCase技巧

    1.在idea中下载插件CamelCase插件  2.使用Shift+Alt+U快捷键进行转换 3.由于转换格式比较导致多次使用快捷键才能达到自己想要的效果,此插件提供了允许禁用某些转换或更改它们在首 ...

  7. Python学习笔记4:函数

    1.函数 函数就是一段具有特点功能的.可重用的语句组. 在Python中函数是以关键词 def 开头,空格之后连接函数名和圆括号(),最后一个冒号:结尾. 函数名只能包含字符串.下划线和数字且不能以数 ...

  8. Spring源码之IOC容器创建、BeanDefinition加载和注册和IOC容器依赖注入

    总结 在SpringApplication#createApplicationContext()执行时创建IOC容器,默认DefaultListableBeanFactory 在AbstractApp ...

  9. 如何通过iptables代理访问内网

    场景 A机器能够联通内网机器,B机器能够联通A机器,但是访问不到内网机器,场景是希望通过A机器能够转发直接联通局域网内的其它机器 机器IP 内网为172.0.0.x/24 A机器为172.0.0.10 ...

  10. JS控制Video播放器(快进、后退、播放、暂停、音量大小)

    思路: 一.首先监听触发事件. 比如:向上键对应的keyCode为38,向下键对应的keyCode为40,向左键对应的keyCode为37,向右键对应的keyCode为39,空格键对应的keyCode ...