91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

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

在C語言中,我們可以使用棧數據結構來實現括號匹配檢查

#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;
}

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

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

盐津县| 胶南市| 安远县| 陈巴尔虎旗| 美姑县| 琼海市| 耒阳市| 姜堰市| 湘西| 光山县| 阿鲁科尔沁旗| 射阳县| 儋州市| 内丘县| 宜章县| 绵阳市| 岳普湖县| 修武县| 荆门市| 八宿县| 托里县| 南召县| 东乡县| 安义县| 淮滨县| 衡东县| 十堰市| 姜堰市| 甘孜| 疏附县| 东源县| 卢氏县| 通州区| 湟中县| 大冶市| 望奎县| 酉阳| 德化县| 桃园市| 竹溪县| 永昌县|