数据结构复习(持续更新)

试卷1:

一、算法设计题

1.已知Q是一个非空队列,S是一个空栈。使用Pascal或C语言编写一个算法,仅用队列和栈的ADT函数和少量工作变量,将队列Q中所有元素逆置。

顺序取出队元素,入栈;所有元素入栈后,再从栈中逐个取出,入队。算法如下:

cpp 复制代码
reverse_queue(queue q.stack s){
//用栈s逆置队列q
    while !isempty(q){//取所有队列元素入栈 只要队列不为空就出队入栈
        data=dequeue(q);
        push(s,data);
    }//while
    while !isempty(s){//取所有栈元素入队 只要栈不为空就继续出站入队
        data=pop(s);
        enqueue(q.data);
    }//while
}//reverse_queue

2.

cpp 复制代码
unsigned char isBalanced(char * string) {
    int i = 0;
    char c;
    
    while (string[i] != '\0') {
        char ch = string[i]; // 获取当前字符
        
        // 1. 如果是左括号,直接压栈
        if (ch == '(' || ch == '[' || ch == '{') {
            push(ch);
        } 
        // 2. 如果是右括号,需要检查匹配情况
        else if (ch == ')' || ch == ']' || ch == '}') {
            // 如果栈为空却来了右括号,说明不平衡
            if (isempty()) return 0;
            
            c = pop();
            // 检查弹出的左括号是否与当前右括号匹配
            if ((ch == ')' && c != '(') ||
                (ch == ']' && c != '[') ||
                (ch == '}' && c != '{')) {
                return 0;
            }
        }
        
        i++; // 记得移动到下一个字符,否则会死循环哦!
    }

    // 3. 最后检查:如果字符串遍历完了,栈里还有多余的左括号,也是不平衡
    return isempty() ? 1 : 0;
}
相关推荐
‎ദ്ദിᵔ.˛.ᵔ₎1 天前
LIST 的相关知识
数据结构·list
M--Y1 天前
Redis常用数据类型
数据结构·数据库·redis
༾冬瓜大侠༿1 天前
vector
c语言·开发语言·数据结构·c++·算法
汀、人工智能1 天前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****1 天前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能1 天前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能1 天前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数
CoderCodingNo1 天前
【GESP】C++四、五级练习题 luogu-P1177 【模板】排序
数据结构·c++·算法
汀、人工智能1 天前
[特殊字符] 第76课:单词拆分
数据结构·算法·均值算法·前缀树·trie·单词拆分
ambition202421 天前
斐波那契取模问题的深入分析:为什么提前取模是关键的
c语言·数据结构·c++·算法·图论