Untitled

mail@pastecode.io avatar
unknown
plain_text
5 months ago
2.1 kB
4
Indexable
#include <stdio.h>
#include <string.h>

#define STACK_SIZE 100

char stack[STACK_SIZE][10]; // Stack to hold symbols
int top = -1;               // Index for the top of the stack

// Function to push an element onto the stack
void push(char *str) {
    if (top < STACK_SIZE - 1) {
        strcpy(stack[++top], str);
    } else {
        printf("Stack overflow\n");
    }
}

// Function to pop an element from the stack
void pop() {
    if (top >= 0) {
        top--;
    } else {
        printf("Stack underflow\n");
    }
}

// Function to display the stack's current content
void displayStack() {
    printf("Stack: ");
    for (int i = 0; i <= top; i++) {
        printf("%s ", stack[i]);
    }
    printf("\n");
}

// Main function to implement shift-reduce parser
int main() {
    char input[100]; // Variable to hold user input tokens
    char *token;

    printf("Enter the input string (e.g., 'a a b b'):\n");
    scanf("%99[^\n]", input); // Reading the full input line, up to 99 characters

    token = strtok(input, " "); // Tokenizing the input based on spaces

    while (token != NULL) {
        // Shift operation
        push(token);
        printf("Shift: %s\n", token);
        displayStack();

        // Reduce operation: Simple grammar S -> aSb | ab
        while (1) {
            if (top >= 2 && strcmp(stack[top-2], "a") == 0 && strcmp(stack[top], "b") == 0) {
                pop(); // Remove 'b'
                pop(); // Remove middle element
                pop(); // Remove 'a'
                push("S"); // Push the result 'S'
                printf("Reduce: S -> aSb | ab\n");
                displayStack();
            } else {
                break; // Exit the loop if no reduction is possible
            }
        }

        token = strtok(NULL, " "); // Move to the next token
    }

    // Final check to see if the input is accepted
    if (top == 0 && strcmp(stack[top], "S") == 0) {
        printf("Accepted\n");
    } else {
        printf("Rejected\n");
    }

    return 0;
}
Leave a Comment