牛客小白月赛76 E.括号序列操作专家(贪心)

氧气少年有一个长度为 n的括号序列,括号序列只包含左括号 `(' 和右括号 `)'。

一个括号序列是合法的,当且仅当此括号序列可以通过插入加号 `+' 和数字 1 得到一个正确的算术表达式。例如:括号序列 (())(),(),和 (()(())) 都是合法的,而 )(,(() 和 (()))(不是合法的。

氧气少年的括号序列不一定是合法的。

月色哥哥是一个括号序列的操作专家,他的任务是帮助氧气少年把这个括号序列变成一个合法的序列。

为了把这个括号序列变合法,月色哥哥每次可以进行下面的操作:
 

  •  交换任意两个相邻括号


如果无论月色哥哥怎么操作都无法使括号序列变合法,输出 −1;否则请输出他需要做的最少的操作次数。

输入描述:

第一行包含一个整数 T(1≤T≤105),表示测试用例的组数。对于每组测试用例:第一行包含一个整数 n(1≤n≤2⋅105),表示括号序列的长度。第二行包含一个长度为 n 的字符串,表示该括号序列。保证字符串只包含左括号 `(' 和右括号 `)'。保证对于所有的测试用例,n 的总和不超过 2⋅105。

输出描述:

对于每组测试用例:仅输出一行,包含一个整数。如果无论怎么操作都无法使括号序列变合法,输出 −1;否则请输出他需要做的最少的操作次数。

示例1

输入

3
4
())(
2
((
20
))()())(()()()((())(

输出

1
-1
17

采取贪心的算法,如果此时碰到的是")",且前面出现过"(",那么直接消掉最近的"("

如果此时碰到的是"(",且前面也有")",那么消掉最远的")"

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
char s[200001];
int main()
{int t;cin>>t;while(t--){int n;cin>>n;cin>>s+1;ll cnt=0;for(int i=1;i<=n;i++){if(s[i]==')') cnt++;else cnt--;}if(cnt){cout<<"-1"<<endl;continue;}ll ans=0,lb=0,rb=0;for(int i=1;i<=n;i++){if(s[i]==')'){if(lb)lb--;elserb++;}else{if(rb){ans+=rb;rb--;}elselb++;}}cout<<ans<<endl;}return 0;
}

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

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

相关文章

7月27日,每日信息差

1、万科与万达长春合作项目纠纷已基本达成和解&#xff0c;万达商管部分被冻结股权即将解冻 2、WPS AI海外版开启公测.由OpenAI和PaLM2提供大模型支持。目前&#xff0c;WPS AI在Windows和Android端的WPS Office的文字和PDF组件上可用。未来&#xff0c;它将嵌入到文字、演示文…

Git基本操作

Git使用 1.命令行操作 1.1 本地库操作 1.1.1 本地库初始化 命令&#xff1a; git init 效果&#xff1a; 注意&#xff1a;.git目录中存放的是本地库相关的子目录和文件&#xff0c;不能删除和修改。 1.1.2 设置签名 作用&#xff1a;区分不同的开发人员身份 格式&…

思科路由器交换机密码破解教程

1. 路由器密码的恢复. 2600、3600等新系列路由器步骤&#xff1a; 1、启动路由器&#xff0c;60秒内按下ctrlbreak键2、rommon>confreg 0x21423、rommon>reset4、router#copy startup-config running-config5、router(config)#no enable secrect //可以删除密码也可以更…

Taskfile demo

https://github.com/yangyang5214/blog/issues/1 makefile 很好用&#xff0c;但是有些语法我不会。 go-task yml & shell 不错&#xff0c;推荐 Taskfile.yml https://github.com/go-task/task/blob/main/.golangci.yml # go install github.com/go-task/task/v3/cmd/ta…

【Matlab】基于BP神经网络的多输出数据回归预测(Excel可直接替换数据)

【Matlab】基于BP神经网络的多输出数据回归预测(Excel可直接替换数据) 1.模型原理2.数学公式3.文件结构4.Excel数据5.分块代码6.完整代码7.运行结果1.模型原理 基于BP(Backpropagation)神经网络的多输出数据回归预测,是一种常见的机器学习方法,用于处理多个输出变量的回…

1 js嵌入html使用

1.1 直接在html内部使用js代码 使用script标签&#xff0c;在前后标签内部写的代码即为js代码。 <body><p id"p1">初始段落</p> <!--id是为了定位需要更改内容的标签--><button type"button" onclick"showNum()">…

Tesseract开源的OCR工具及python pytesseract安装使用

一 、介绍 Tesseract是一款由Google赞助的开源OCR。 pytesseract是python包装器&#xff0c;它为可执行文件提供了pythonic API。 Tesseract 已经有 30 年历史&#xff0c;开始它是惠普实验室的一款专利软件&#xff0c;在2005年后由Google接手并进一步开发和完善。Tesseract支…

使用Unsplash API生成随机图片

使用Unsplash API生成随机图片 1、默认随机 示例如下&#xff1a; https://source.unplash.com/random2、指定用户 可以从特定用户账号中生成随机图像。URL格式如下 https://source.unsplash.com/user/{USERNAME}点击示例1https://source.unsplash.com/user/angusyang9/li…

C++《i+1》

欢迎来到 PaQiuQiu 的空间 本文为【C《i1》专栏目录】&#xff0c;方便大家更好的阅读! 写在前面 当今计算机科学领域中最受欢迎和广泛使用的编程语言之一就是C。C是一种高级编程语言&#xff0c;具有强大的功能和广泛的应用领域&#xff0c;包括系统级编程、游戏开发、图形用…

tp5 链表查询,查出left表为空的数据

背景&#xff1a;tp5 A,B两表join链表查询&#xff0c;查出B表数据为空的A表数据 以及 B表数据不为空的A表数据 此操作将使用到 EXP 和 IS NULL 查出B表数据为空的A表数据SQL $where[] [exp,Db::raw("b.id IS NULL")];$list db(table1)->alias(a)->join(ta…

go语言中defer执行顺序

defer 执行顺序和调用顺序相反&#xff0c;类似于栈后进先出。 defer在 return 之后执行&#xff0c;但在函数推出之前&#xff0c;defer可以修改返回值。 func test() int {i : 0defer func() {fmt.Println("defer1")}()defer func() {i 1fmt.Println("defe…

YOLOv7 论文学习

1. 解决了什么问题&#xff1f; 实时的目标检测器是计算机视觉系统的重要组成部分。目前应用在 CPU 端的实时目标检测方法大多基于 MobileNet、ShuffleNet、GhostNet&#xff0c;而用在 GPU 的实时目标检测方法大多基于 ResNet、DarkNet、DLA&#xff0c;然后使用 CSPNet 策略…

Doris 部署

介绍 Apache Doris 是一个基于 MPP 架构的高性能、实时的分析型数据库&#xff0c;以极速易用的特点被人们所熟知&#xff0c;仅需亚秒级响应时间即可返回海量数据下的查询结果&#xff0c;不仅可以支持高并发的点查询场景&#xff0c;也能支持高吞吐的复杂分析场景。基于此&a…

MLP-Mixer:面向视觉的全mlp架构

文章目录 MLP-Mixer: An all-MLP Architecture for Vision摘要本文方法代码实验结果 MLP-Mixer: An all-MLP Architecture for Vision 摘要 卷积神经网络(cnn)是计算机视觉的首选模型。 最近&#xff0c;基于注意力的网络&#xff0c;如VIT&#xff0c;也变得流行起来。在本文…

@ImportResource 注解的使用

ImportResource注解&#xff1a;用于导入 Spring 的 xml 配置文件&#xff0c;让该配置文件中定义的 bean 对象加载到Spring容器中。 1.Spring 方式的配置文件 beans.xml <?xml version"1.0" encoding"UTF-8"?> <beans xmlns"http://www…

【Logback】Spring boot 配置多环境的logback

一、背景描述 由于MAC环境本地启动项目存在目前权限问题&#xff0c;需要与测试环境不一致只&#xff0c;为了不每次修改代码都修改本地目录&#xff0c;则想配置日志目录的多环境支持 二、实现方案 1、application-local.yml配置 logging:config: classpath:logback-sprin…

leetcode刷题记录

1.二分法 class Solution { public:int search(vector<int> &nums, int target) {int left 0, right nums.size() - 1;while(left < right) {int mid left ((right - left) >> 1);if(nums[mid] > target) {right mid -1;} else if(nums[mid] < …

详解Linux手动释放缓存的方法

详解Linux手动释放缓存的方法 Linux释放内存的命令&#xff1a; sync echo 1 > /proc/sys/vm/drop_caches0&#xff1a;不释放&#xff08;系统默认值&#xff09; 1&#xff1a;释放页缓存 2&#xff1a;释放dentries和inodes 3&#xff1a;释放所有缓存 释放完内存后改回…

深入浅出Pytorch函数——torch.nn.Softmax

分类目录&#xff1a;《深入浅出Pytorch函数》总目录 相关文章&#xff1a; 机器学习中的数学——激活函数&#xff1a;Softmax函数 深入浅出Pytorch函数——torch.softmax/torch.nn.functional.softmax 深入浅出Pytorch函数——torch.nn.Softmax 将Softmax函数应用于 n n n…

消息中间件ActiveMQ介绍

一、消息中间件的介绍 介绍 ​ 消息队列 是指利用 高效可靠 的 消息传递机制 进行与平台无关的 数据交流&#xff0c;并基于 数据通信 来进行分布式系统的集成。 特点(作用) 应用解耦 异步通信 流量削峰 (海量)日志处理 消息通讯 …... 应用场景 根据消息队列的特点&a…