Codeforces Round #849 (Div. 4) D Distinct Split

news2025/1/17 4:10:44

题目:

大概翻译:

让我们把一个字符串x的f(z)函数表示为该字符串包含的不同字符数。例如,f(abc)=3。

f(bbbb) = 1, 和 f(babacaba) = 3.

给定一个字符串s,将其分成两个非空字符串a和b,使f(a)+f(b)为最大可能。换句话说,找出

换句话说,找到f(a)+f(b)的最大可能值,使a+b=s(字符串a和字符串b的连接等于字符串s)。

输入]。

输入由多个测试案例组成。第一行包含一个整数t(1<t<104)--测试案例的数量。测试用例的描述

测试用例的描述如下。

每个测试用例的第一行包含一个整数n(2 < n < 2- 10°)--字符串s的长度。

第二行包含字符串s,由小写英文字母组成。

保证所有测试案例的n之和不超过2-10°。

输出

对于每个测试案例,输出一个整数--f(a)+f(b)的最大可能值,即ata+b=s。

大致意思 :给出一段字符串,我们要将其分为两段,我们要求这两段分别求出不重复的字符数的数量和

(这两段已经相互独立了),最大值。

大致思路:遍历所有情况;

#include <iostream>
#include <stdio.h>
#include <algorithm>
#include <cstring>
#include <cmath>
#include <vector> 
#include <map>
#include <stack>
#include <queue>
#include <set>
using namespace std;
typedef long long ll;
int n, m, t, now, l, r, c, b, T, k;
const int INF = 0x3f3f3f3f;
const double pi = acos(-1.0);
int pie[] = { 3,1,4,1,5,9,2,6,5,3,5,8,9,7,9,3,2,3,8,4,6,2,6,4,3,3,8,3,2,7,9,5,0,2,8,8,4,1,9,7,1,6,9,3,9,9,3,7,5,1,0 };
int step[50][50][50];
int nx, ny, nz, ex, ey, ez;
int sum[20221199];
int w[50];
int  dp[50];
ll mod = 1e9 + 7;
string ss = "codeforces";
char p[2252225];
void check()
{
    cin >> m;//输入要遍历的字符的总值
    cin >> p + 1;
    memset(w, 0, sizeof(w));//初始化前一段的能得到的值总数
    memset(dp, 0, sizeof(dp));//初始化后一段的值的总数
    for (int i = 1; i <= m; i++)//这也属于初始化的一部分,也就是在当前位置停下分段所能的到的当前的状态
    {
        dp[p[i] - 'a'] ++;
    }
    int ans = 0;
    for (ll i = 1; i <= m; i++)//开始遍历所有的情况
    {
        w[p[i] - 'a'] ++;//在第一 , 2 , 3 , 4个停下来的话
        dp[p[i] - 'a'] --;//剩下的会剩多少
        int ans2 = 0;
        for (int j = 0; j < 26; j++)//检查前一段多少
        {
            if (w[j] != 0)
            {
                ans2++;
            }
        }
        for (int j = 0; j < 26; j++)//检查后一段有多少
        {
            if (dp[j] != 0)
            {
                ans2++;
            }
        }
        ans = max(ans2, ans);//遍历所有情况求出最大值
    }
    cout << ans << endl;
}
int main()
{
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    cin >> n;
    while (n--)
    {
        check();
    }
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/197983.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2023软考软件设计师易混淆知识点~(7)

将2023上半年软考《软件设计师》易混淆知识点&#xff0c;分享给大家&#xff0c;快来跟着一起打卡学习吧&#xff01;--<<<点击链接加入群聊【软考学习交流群】>>>易混淆点 :对称加密和非对称加密1、对称加密技术:KeKd;加密解密共用一个密钥;特点:加密强度不…

python设计模式-适配器设计模式,装饰器设计模式

适配器设计模式 适配器模式可用作两个不兼容接口之间的桥梁。 这种类型的设计模式属于结构模式&#xff0c;因为此模式结合了两个独立接口的功能。 这种模式涉及一个类&#xff0c;它负责连接独立或不兼容接口的功能。 一个现实的例子是读卡器&#xff0c;它是存储卡和笔记本电…

超多免费API接口分享

分享一下近段时间在网上看的超多免费API接口&#xff0c;赶紧收藏起来吧&#xff01; 一、APISpace 为超过100 万开发者提供专业的 API 服务&#xff0c;包括 API 管理、测试、访问控制等功能&#xff0c;让您无忧探索广阔的API世界~所有接口提供免费试用 https://www.apisp…

【最坏贪心】代码源每日一题div1 排列 2023.02.03

排列 - 题目 - Daimayuan Online Judge今天牛牛完结撒花辣&#xff01;但是我还没补完题&#xff0c;感觉这几场rk都差不多&#xff0c;但是总体来说感觉签到签的有点困难&#xff0c;然后好不容易开到算法题&#xff0c;算法的题也最多只能出一题然后后面这几天除了vpCF&#…

现在都这么拽吗?面试一个工作4年的测试工程师,连自动化基础都搞不清楚,还反过来怼我....

年后招聘黄金期&#xff0c;我们公司也开始大量招人了&#xff0c;我这次是公司招聘的面试官之一&#xff0c;主要负责一些技术上的考核&#xff0c;这段时间还真让我碰到了不少奇葩求职者 昨天公司的HR小席刚跟我吐槽&#xff1a;这几个星期没有哪天不加班的&#xff01;各种…

代码随想录 day55动态规划 回文子串

代码随想录 day55动态规划 回文子串 题647 回文子串 动态规划解法&#xff1a; 1&#xff0c;确定dp数组以及下标的含义 对于绝大多数题目来说&#xff0c;题目求什么dp数组就定义为什么&#xff0c;但此题如果定义&#xff0c;dp[i] 为 下标i结尾的字符串有 dp[i]个回文串的…

【2003NOIP普及组】T3.栈 试题解析

【2003NOIP普及组】T3.栈 试题解析 时间限制: 1000 ms 内存限制: 65536 KB 【题目描述】 栈是计算机中经典的数据结构,简单的说,栈就是限制在一端进行插入删除操作的线性表。 栈有两种最重要的操作,即pop(从栈顶弹出一个元素)和push(将一个元素进栈)。 栈的重要…

对比coco anationtions和coco result的数据保存形式

一、背景 coco anationtions是coco数据集提供的数据标签&#xff0c;coco result是预测的结果的形式&#xff0c;方便用pycocotools计算模型的map等指标。 二、两种数据形式对比 1. coco anationtions的形式 以person_keypoints_val2017.json为例。整体结构如下图 是一个字…

服务器搭建原神私服教程

1. 准备工具这个端在Windows、Linux系统上都可以跑&#xff0c;本次教程基于Linux。准备如下工具服务器1台 centos7 系统 最低配置8核16G 如需公网联机可用云服务器手保证云服务器的443端口未使用&#xff08;服务器上没有网站&#xff09;2. 环境配置安装系统依赖环境yum -y i…

揭密字节跳动薪资职级,资深测试居然能拿......

曾经的互联网是PC的时代&#xff0c;随着智能手机的普及&#xff0c;移动互联网开始飞速崛起。而字节跳动抓住了这波机遇&#xff0c;2015年&#xff0c;字节跳动全面加码短视频&#xff0c;从那以后&#xff0c;抖音成为了字节跳动用户、收入和估值的最大增长引擎。 自从字节逐…

论文阅读_模型鲁棒性的量化指标

论文信息 name_en: Robustness Metrics&#xff1a;How Are They Calculated, When Should They Be Used and Why Do They Give Different Results? name_ch: 鲁棒性度量&#xff1a;它们是如何计算的&#xff0c;何时应该使用以及为什么会给出不同的结果? addr: http://doi…

软件工程(2)--瀑布模型

前言 这是基于我所学习的软件工程课程总结的第二篇文章。 在20世纪80年代之前&#xff0c;瀑布模型一直是唯一被广泛采用的生命周期模型&#xff0c;现在它仍然是软件工程中应用得最广泛的过程模型。传统软件工程方法学的软件过程&#xff0c;基本上可以用瀑布模型来描述。 正…

【OpenGL学习】光照贴图

光照贴图 上节中我们给物体添加了材质&#xff0c;使得物体能够对光照做出不同的反应&#xff0c;但是有个问题就是&#xff0c;使用该种材质的物体&#xff0c;只能够表现出我们所定义的一种性质&#xff0c;而实际生活中我们的一个物体往往具有多种材质&#xff0c;因此本节…

一文了解jquery

簡述本文主要介紹jquery的重要語法功能&#xff0c;如選擇器&#xff0c;dom操作&#xff0c;事件等處理操作什麼jquery&#xff1f;jquery由美国人John Resig&#xff08;约翰莱西格&#xff09;于2006年创建 ,是目前最流行的JavaScript程序库。以輕量&#xff0c;代碼簡潔&am…

windows快速切换jdk版本号

前言 因为老项目和新项目的需要&#xff0c;在电脑上需要切换jdk1.8和jdk17&#xff08;其它版本jdk同样可以切换&#xff09;。网上有修改配置文件的方式&#xff0c;但是感觉比较繁琐&#xff0c;后来找到了通过bat文件和环境变量来快速切换jdk环境的方法。这里记录分享出出…

rclone挂载webdav详细步骤(含脚本)

挂载说明 文章目录挂载说明文件下载地址&#xff1a;文件夹及文件说明windows安装、配置和挂载操作步骤安装新建连接配置挂载开机自启linux安装、配置和挂载操作步骤安装新建连接配置,见 [链接新建连接配置](#新建连接配置)挂载linux开机自启文件下载地址&#xff1a; 文件下载…

如何实现前端全屏

前言 最近有个需求是要求免登录自动打开看板&#xff0c;然后全屏并播放视频。当然最后自动全屏并播放视频没有实现&#xff0c;写这篇文章是为了记录一下踩的坑。 全屏 网上有挺多现成的组件的&#xff0c;这里就不介绍了&#xff0c;可以自行百度。这里只说通过原生的方法…

手机更换电池-小米8se操作步骤

目录 准备工具&#xff1a; 步骤&#xff1a; 注意事项&#xff1a; 准备工具&#xff1a; 需要更换电池的手机电池背胶&#xff08;左上蓝色&#xff09;缠胶棍&#xff08;手机左边&#xff09;小螺丝刀新电池卡针后盖拆卸片&#xff08;右上三角&#xff09;吸盘后盖背胶 …

Cesium 点位聚合

实现效果 实现方式 通过 new Cesium.EntityCluster(options) 接口对象实现而 new Cesium.DataSource() 有成员变量 clusteringclustering 类型是 EntityCluster代码实现,基于 vue 前端框架 这里使用的是 cesium 沙盒演示中自带的数据进行实现 加载数据 getKMLDTSource() {let o…

cnetsdk:.NET OCR SDK-支持中文-Crack

产品概览 .NET OCR SDK 许可证和价格 OCR SDK 兼容性 CnetSDK .NET OCR Scanner SDK兼容.NET Framework 4.0及以上版本。此 OCR 库软件可用于在任何 CPU 上进行 .NET OCR Windows 和基于服务器的应用程序开发。我们为 x86 和 x64 系统提供 OCR 库解决方案。 OCR 图像格式 这个 …