Java ile Algoritma tasarım sorusu

A Çevrimdışı

annonesm

Kıdemli Üye
Kayıtlı
7 Aralık 2024
10
1
5
Bir parantez dizisi verildiğinde, bir yığın kullanarak parantezlerin dengeli olup olmadığını nasıl belirlerim?

Kod:
import java.util.Stack;

public class BalanceParentheses {

    public static boolean checkBalancedParentheses(String s) {
        Stack<Character> stack = new Stack<>();
        for (int i = 0; i < s.length(); i++) {
            char c = s.charAt(i);
            if (c == '(' || c == '{' || c == '[') {
                stack.push(c);
            } else if (c == ')' || c == '}' || c == ']') {
                if (stack.isEmpty()) {
                    return false;
                }
                char top = stack.pop();
                if ((c == ')' && top != '(') || (c == '}' && top != '{') || (c == ']' && top != '[')) {
                    return false;
                }
            }
        }
        return stack.isEmpty();
    }

    public static void main(String[] args) {
        String s = "{([])}";
        boolean isBalanced = checkBalancedParentheses(s);
        if (isBalanced) {
            System.out.println("Parentheses are balanced");
        } else {
            System.out.println("Parentheses are not balanced");
        }
    }
}
 
287Konular
705Mesajlar
282Kullanıcılar
denizkızıSon üye
Üst