日常练习19——判断是否为合法字符串

本文介绍了一种用于判断括号串是否合法的算法,通过遍历字符串并使用计数器来跟踪括号的开闭状态,确保每个左括号都有对应的右括号。此算法在字符串处理和语法分析中具有广泛应用。

给定一个字符串A和它的长度n,判断是否为一个合法的括号串。
判断括号串是否合法即括号是否匹配,是否成对出现


import java.util.*;

public class test3 {
    public static  boolean chkParenthesis(String A, int n) {
        char[] arrC = A.toCharArray();
        int num = 0;
        int i = 0;
        while(i < arrC.length && num >= 0){
            if(arrC[i] == '('){
                num++;
            }else if(arrC[i] == ')'){
                num--;
            }
            i++;
        }
        if(i < arrC.length || num != 0){
            return false;
        }

        return true;
    }

    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String str1 = scanner.nextLine();
        Integer n = scanner.nextInt();
        System.out.println(chkParenthesis(str1,n));

    }
}

运算结果:

( ( ( ( ) ) ) )
8
true

 

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值