[LeetCode]—Longest Valid Parentheses 最长括号匹配

本文详细介绍了如何通过栈和动态规划解决寻找字符串中最长有效括号子串的问题,并提供了两种算法的实现代码。通过实例分析和代码解释,深入理解长有效括号子串的计算方法。

Longest Valid Parentheses

 

Given a string containing just the characters '(' and ')', find the length of the longest valid (well-formed) parentheses substring.

For "(()", the longest valid parentheses substring is "()", which has length = 2.

Another example is ")()())", where the longest valid parentheses substring is "()()", which has length = 4.

分析:

       由于是计算长度,直接单纯栈并不能解决问题。但是如果可以用栈记录下标,那么还是可以求解的。

       方法一:用栈存储“)”的下标,当遇到“(”的时候进行分析,时间复杂度O(N):

      从前之后,遍历string。遇到“(”入栈,遇到“)”讨论。其中last记录最后不匹配的下标,初始化为-1。

    1、此时栈为空,那说明“)”不能匹配。用last记录下其坐标。

    2、当栈不为空时,匹配上,出栈后:(1)此时栈依然不空,那么当前可匹配的括号为i-st.top();

                                                                      (2)此时栈空了,说明之前全部匹配上。那么最后一个没匹配的存在last中。i-last就是之前匹配上的括号的数目。

 

 代码出自:https://gitcafe.com/soulmachine/LeetCode

class Solution{
public:
       int longestValidParentheses(string s){
        stack<int>  st;  //存的是‘(’的下标
        int max_len=0,last=-1;  //last 存的是最后一次没匹配的')'
        
        for(int i=0;i<s.size();i++){
           if(s[i]=='('){
               st.push(i);
            }else{  //重点考察“)”,以找到以第一个未被匹配的“(”为参考。
              if(st.empty()){
                 last=i;
                }
               else {
                   st.pop();
                   if(st.empty())
                        max_len=max(max_len,i-last);
                   else{
                     max_len=max(max_len,i-st.top());
                   }
                }
            }
        }
        return max_len;

        }

};

方法二:用一维动态规划逆向求解。dp[i]表示从s[i]到s[s.length - 1]包含s[i]的最长的有效匹配括号子串长度。

方法出自:http://blog.csdn.net/yapian8/article/details/28239003


class Solution {
public:
    int longestValidParentheses(string s) {
       int n=s.length();
       if(n<2)return 0;
       int *dp=new int[n];
       int max_len=0;
        for(int i=0;i<n;i++)
            dp[i]=0;
        for(int i=n-2;i>=0;i--){
          if(s[i]=='('){   //只处理“(”,右括号设为0
             int j=i+1+dp[i+1];  
             if(s[j]==')'&& j<n){  
                dp[i]=dp[i+1]+2;
              if(j+1<n)
                    dp[i]+=dp[j+1];
                } 
            }
             max_len=max(max_len,dp[i]);
        }
         return max_len;
    }
};

(1)求职者端(Web 前端) 岗位浏览与搜索: 智能推荐首页:基于 “专业背景 + 求职意向” 推荐匹配岗位(如 “计算机专业硕士” 优先推荐 “高校计算机教师岗”“实验员岗”),展示岗位核心信息(学校名称、岗位名称、薪资范围、截止日期)。 多条件筛选:支持按 “岗位类型(教学岗 / 科研岗 / 行政岗)、学历要求(硕士 / 博士)、地区(华北 / 华东等)、学校层次(985/211 / 双非)” 组合筛选,结果按 “匹配度 / 发布时间 / 薪资” 排序。 岗位详情页:展示 “岗位职责、任职要求、福利待遇、应聘流程、联系人信息”,提供 “收藏岗位、一键投递简历、查看该岗位竞争热度(如‘已有 230 人投递’)” 功能。 个人求职中心: 简历管理:支持创建多版本简历(如 “教学岗专用简历”“科研岗专用简历”),包含 “基本信息、教育经历、科研成果、教学经验、获奖情况” 等模块,支持 PDF 导出和在线编辑。 应聘跟踪:记录 “已投递岗位、简历状态(已接收 / 筛选中 / 面试通知 / 已录用)、截止日期提醒”,对 “3 天内即将截止的岗位” 自动推送提醒。 竞争分析:针对已投递岗位,展示 “求职者学历分布(博士占比 75%)、专业匹配度排名(你的匹配度 85 分,超过 80% 竞争者)”,辅助评估自身竞争力。 (2)高校招聘负责人端(Web 管理端) 岗位管理: 岗位发布:填写 “岗位名称、招聘人数、学历要求、专业方向、岗位职责、薪资范围、应聘方式” 等信息,支持上传 “岗位说明书附件”,设置 “自动截止日期” 和 “简历接收邮箱”。 批量操作:对 “已过期岗位” 进行批量下架,对 “热门岗位(投递量>100)” 设置 “自动置顶”,支持 “岗位信息批量导出(Excel 格式)”。 简历筛选: 智能初筛:系统自动对投递简历进行 “匹配度评分”
(1)车主移动端(以微信小程序为例) 首页核心功能: 附近停车场推荐:基于手机 GPS 定位,展示 3 公里内停车场的 “剩余车位数量、距离、收费标准、用户评分”,支持按 “距离最近 / 车位最多 / 价格最低” 排序,点击可导航至停车场(对接高德 / 百度地图 API)。 预约车位:选择目标停车场与预计入场时间(如 “15:00-16:00”),预约成功后生成 “预约凭证”,系统为预约车位预留 15 分钟(超时未入场自动释放),避免 “到店无位”。 快捷缴费入口:支持 “扫码缴费”(扫描停车场出口二维码)或 “无感支付”(绑定微信 / 支付宝免密支付,离场时自动扣费),缴费后生成 “离场凭证”,出口闸机自动识别放行。 个人中心功能: 停车记录:展示近 3 个月的 “停车场名称、入场时间、离场时间、停车时长、缴费金额、支付状态”,支持按时间筛选,点击记录可申请电子发票(填写抬头后自动发送至邮箱)。 车辆管理:支持绑定 1-3 辆常用车辆(录入车牌号码、车辆类型如 “小型轿车 / SUV”),绑定后入场时无需重复扫码,系统自动识别车牌关联车主账号。 (2)管理员 Web 端 实时监控面板: 车位状态总览:以 “停车场平面图” 形式展示所有车位(红色 = 已占用、绿色 = 空闲、黄色 = 预约中),点击单个车位可查看 “当前占用车辆的车牌、入场时间、预计离场时间”。 异常告警提示:实时弹窗提示 “识别失败(如车牌模糊)”“超时未缴费”“车位占用异常(如车辆停留超 24 小时)”,管理员可点击处理(如手动输入车牌、联系车主)。 运营管理功能: 费率配置:支持按 “时段(如白天 8:00-20:00 / 夜间 20:00-8:00)、车型(小型车 / 大型车)、节假日” 设置差异化费率(如 “白天 5 元 / 小时,夜间 3 元 / 小时,节假日上浮 20%”),配置后实时生效。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值