洛谷 T89643 回文串(并查集)

洛谷:https://www.luogu.org/problem/T89643
 题目描述
 由于 Kiana 实在是太忙了,所以今天的题里面没有 Kiana。 有一个长度为 N 的字符串 S,有 K 条信息,每条信息为一个区间 [l,r],表示 S[l],S[l+1],……,S[r]是一个回文串。 出题人想知道,这个字符串中最多有多少种不同的字符。由于她 不会算,所以希望由你告诉她。
 输入格式
输入文件包括 K+1 行。 第一行包含两个正整数 N 和 K,分别表示字符串的长度和给定信 息的数量。 接下来 K 行,每行包含两个正整数 l 和 r,表示 S[l],S[l+1],……,S[r] 是一个回文串。
输出格式
输出文件包括一行。 第一行包含一个正整数,表示给出的字符串中最多有多少种不同 的字符。
分析:

8 4

1 5

3 4

7 8

2 6
因为1,5之间的字符串是回文的,所以1,5;2,4;对应字符相同;

同理 3 4字符相同,所以 2 3 4 字符相同,7 8 字符相同;

2,6: 2,6字符相同,所以2 3 4 6相同 ;3 5 相同,进一步得1 2 3 4 5 6相同
这些一步一步合并的过程是不是很像并查集?bingo!这道题就用并查集做,以下是AC


#include<bits/stdc++.h>
using namespace std;
const int maxn = ;
int n, k;
int f[maxn], root[maxn];
int sum;
int getc(int k) {//寻找父亲并更新路径上所有节点(路径压缩)
if (k == f[k])return k;
else return f[k] = getc(f[k]);
}
void un(int x, int y) {//带秩合并,更快一些,有的题会对秩进行操作
x = getc(x), y = getc(y);
if (root[x] > root[y])
f[y] = x;
else {
f[x] = y;
if (root[x] == root[y])
root[y]++;
}
}
int main() {
freopen("shuru.txt", "r", stdin);
ios::sync_with_stdio(false);
cin >> n >> k;
if (n < ) {
if (n == )cout << << endl;
else cout << << endl;
return ;
}
for (int i = ; i <= n; i++)f[i] = i;
int l, r;
for (int i = ; i <= k; i++) {
cin >> l >> r;
for (int j = l, q = r; j < q; j++, q--) {//回文串从两端向中间,每对字符都是相同的,相同的字符加入一个并查集
un(j, q);
}
}
for (int i = ; i <= n; i++) {
if (getc(i) == i)sum++;//有多少个字符是不同的,因为要求最大所以每个都+1
////可能有的点只是挂上了还没更新1->5->9   11->12 f[9]=12,但此时f[1]还未更新为12,所以要再求一次find
}
cout << sum << endl;
}

洛谷T89644 palindrome回文串的更多相关文章

  1. 【洛谷P3649】回文串

    题目大意:给定一个长度为 N 的字符串,定义一个变量为该字符串的回文子串长度乘以该字串出现的次数,求这个变量的最大值是多少. 题解:学会了回文自动机. 回文自动机是两棵树组成的森林结构,并通过 fai ...

  2. 洛谷P3649 [APIO2014]回文串(回文自动机)

    传送门 话说回文自动机我自己都还没搞懂呢…… 等到时候会了再来填坑 //minamoto #include<cstdio> #include<cstring> #define ...

  3. 题解 洛谷 P2010 【回文日期】

    By:Soroak 洛谷博客 知识点:模拟+暴力枚举 思路:题目中有提到闰年然后很多人就认为,闰年是需要判断的其实,含有2月29号的回文串,前四位是一个闰年那么我们就可以直接进行暴力枚举 一些小细节: ...

  4. hdu 1159 Palindrome(回文串) 动态规划

    题意:输入一个字符串,至少插入几个字符可以变成回文串(左右对称的字符串) 分析:f[x][y]代表x与y个字符间至少插入f[x][y]个字符可以变成回文串,可以利用动态规划的思想,求解 状态转化方程: ...

  5. 洛谷——P1609 最小回文数

    题目描述 回文数是从左向右读和从右向左读结果一样的数字串. 例如:121.44 和3是回文数,175和36不是. 对于一个给定的N,请你寻找一个回文数P,满足P>N. 满足这样条件的回文数很多, ...

  6. 洛谷—— P1609 最小回文数

    https://www.luogu.org/problemnew/show/1609 题目描述 回文数是从左向右读和从右向左读结果一样的数字串. 例如:121.44 和3是回文数,175和36不是. ...

  7. 洛谷 P1609 最小回文数 题解

    这题其实并不难,重点在你对回文数的了解,根本就不需要高精度. 打个比方: 对于一个形如 ABCDEFGH 的整数 有且仅有一个比它大的最小回文数 有且仅有一个比它小的最大回文数 而整数 ABCDDCB ...

  8. 洛谷 U3346 A1-偶回文数

    U3346 A1-偶回文数 题目背景 方方方很喜欢回文数,于是zzq就出了一道关于回文数的题目. 因为偶回文数比较简单,所以方方方就把它放在了第一题... 题目描述 我们定义一个长度为偶数的回文数叫做 ...

  9. 【洛谷p1217】回文质数

    回文质数[题目链接] 始终要记得凌云壮flag(真香) 说是个搜索,其实感觉更像是一个暴力: 这个题的难度并不是特别大,因为下面的提示太明显了qwq,(而且之前培训也讲过)首先是构造回文数,构造回文数 ...

随机推荐

  1. Java学习day6数组

    ---恢复内容开始--- Java数组 Java 语言中提供的数组是用来存储固定大小的同类型元素.你可以声明一个数组变量,如 numbers[100] 来代替直接声明 100 个独立变量 number ...

  2. Qt5 对xml文件常用的操作(读写,增删改查)

    转自:https://blog.csdn.net/hpu11/article/details/80227093 项目配置 pro文件里面添加QT+=xml include <QtXml>, ...

  3. 什么是http协议??

    一.http协议的定义: http(Hypertext transfer protocol)超文本传输协议,通过浏览器和服务器进行数据交互,进行超文本(文本.图片.视频等)传输的规定.也就是说,htt ...

  4. ASP.NET @URL帮助类

    原文: https://www.cnblogs.com/bobo-show/p/5746389.html    https://www.cnblogs.com/zhuji/p/7698057.html ...

  5. Django 的 logging日志文件配置

    在Django的settings配置文件里配置以下信息: import os BASE_LOG_DIR = os.path.join(BASE_DIR , "log") # log ...

  6. Linux awk抓取IP的两种方式

    ip addr show ens33 | awk -F "[ /]+" '/inet /{print $3}' 或 ifconfig ens33 | awk -F "[ ...

  7. 对于call,apply,bind 的理解

    JavaScript 中 call().apply().bind() 的用法 之前对与JavaScript中的call,apply,bind这几个方法一直理解的很模糊,今天总结一下. 例1 var n ...

  8. JSP2的自定义标签和方法

    Jsp2的自定义标签 Jsp2 开发标签库的几个步骤: 开发自定义标签处理类. 建立一个*.tld文件,每个tld文件对应一个标签库,每个标签库可对应多个标签. 在jsp文件中使用自定义标签 空标签 ...

  9. 2018-11-15-UWP-how-to-get-the-touch-width

    title author date CreateTime categories UWP how to get the touch width lindexi 2018-11-15 18:49:12 + ...

  10. django 多条数据显示的坑(怪自己)

    今天的问题是,一个接口执行了很多次,每次都会在结果表里面记录一条结果信息,在查看接口详情页面,我想只展示一条,然后就进入误区了 第一个是怪自己手残,api_id  被自己写成app_id了 第二个是筛 ...