溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

C語言字符串中的括號匹配檢查

發(fā)布時(shí)間:2024-08-30 14:33:51 來源:億速云 閱讀:79 作者:小樊 欄目:編程語言

在C語言中,我們可以使用棧數(shù)據(jù)結(jié)構(gòu)來實(shí)現(xiàn)括號匹配檢查

#include<stdio.h>
#include <stdlib.h>
#include<string.h>

typedef struct Stack {
    char *data;
    int top;
    int size;
} Stack;

Stack *createStack(int size) {
    Stack *stack = (Stack *)malloc(sizeof(Stack));
    stack->data = (char *)malloc(size * sizeof(char));
    stack->top = -1;
    stack->size = size;
    return stack;
}

void push(Stack *stack, char value) {
    if (stack->top == stack->size - 1) {
        printf("Stack is full\n");
        return;
    }
    stack->data[++stack->top] = value;
}

char pop(Stack *stack) {
    if (stack->top == -1) {
        printf("Stack is empty\n");
        return '\0';
    }
    return stack->data[stack->top--];
}

int isEmpty(Stack *stack) {
    return stack->top == -1;
}

int isMatchingPair(char opening, char closing) {
    if (opening == '(' && closing == ')') return 1;
    if (opening == '{' && closing == '}') return 1;
    if (opening == '[' && closing == ']') return 1;
    return 0;
}

int areBracketsBalanced(char *expression) {
    int length = strlen(expression);
    Stack *stack = createStack(length);

    for (int i = 0; i< length; i++) {
        if (expression[i] == '(' || expression[i] == '{' || expression[i] == '[') {
            push(stack, expression[i]);
        } else if (expression[i] == ')' || expression[i] == '}' || expression[i] == ']') {
            if (isEmpty(stack)) {
                return 0;
            } else {
                char openingBracket = pop(stack);
                if (!isMatchingPair(openingBracket, expression[i])) {
                    return 0;
                }
            }
        }
    }

    return isEmpty(stack);
}

int main() {
    char expression[] = "({[]})";
    if (areBracketsBalanced(expression)) {
        printf("The brackets are balanced\n");
    } else {
        printf("The brackets are not balanced\n");
    }
    return 0;
}

這個(gè)程序首先定義了一個(gè)棧結(jié)構(gòu),然后實(shí)現(xiàn)了創(chuàng)建棧、入棧、出棧等基本操作。接下來,我們定義了一個(gè)isMatchingPair函數(shù),用于判斷兩個(gè)括號是否匹配。areBracketsBalanced函數(shù)遍歷輸入的字符串,遇到開括號就入棧,遇到閉括號就出棧并檢查是否匹配。最后,如果棧為空,說明括號匹配成功,否則失敗。

main函數(shù)中,我們測試了一個(gè)包含圓括號、花括號和方括號的字符串,如果括號匹配,輸出"The brackets are balanced",否則輸出"The brackets are not balanced"。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI