第四十二练 检测循环括号
给定一个字符串,包含括号和其他字符,编写一个程序检测是否存在循环括号,例如 "((a+b))"。
第四十一练答案
下面是一个用C语言实现的将中缀表达式转换为后缀表达式的例子。这个程序使用了栈来辅助转换:
#include <stdio.h> #include <stdlib.h> #include <string.h> // 定义栈结构 typedef struct { char *data; int top; int capacity; } Stack; // 初始化栈 void initializeStack(Stack *stack, int capacity) { stack->data = (char *)malloc(sizeof(char) * capacity); stack->top = -1; stack->capacity = capacity; } // 判断栈是否为空 int isEmpty(Stack *stack) { return stack->top == -1; } // 判断栈是否已满 int isFull(Stack *stack) { return stack->top == stack->capacity - 1; } // 入栈操作 void push(Stack *stack, char element) { if (isFull(stack)) { printf("Stack overflow\n"); return; } stack->data[++stack->top] = element; } // 出栈操作 char pop(Stack *stack) { if (isEmpty(stack)) { printf("Stack underflow\n"); return '\0'; // 返回空字符表示栈已空 } return stack->data[stack->top--]; } // 获取栈顶元素 char peek(Stack *stack) { if (isEmpty(stack)) { return '\0'; // 返回空字符表示栈已空 } return stack->data[stack->top]; } // 判断运算符的优先级 int getPriority(char operator) { switch (operator) { case '+': case '-': return 1; case '*': case '/': return 2; default: return 0; // 非运算符返回0 } } // 中缀表达式转后缀表达式 void infixToPostfix(char *infixExpression, char *postfixExpression) { Stack stack; initializeStack(&stack, 100); // 假设表达式不超过100个字符 int length = strlen(infixExpression); int j = 0; // 用于记录后缀表达式的下标 for (int i = 0; i < length; i++) { char current = infixExpression[i]; if (isalnum(current)) { // 如果是字母或数字,直接输出到后缀表达式 postfixExpression[j++] = current; } else if (current == '(') { // 如果是左括号,入栈 push(&stack, current); } else if (current == ')') { // 如果是右括号,将栈中的运算符出栈并输出到后缀表达式,直到遇到左括号 while (!isEmpty(&stack) && peek(&stack) != '(') { postfixExpression[j++] = pop(&stack); } pop(&stack); // 弹出左括号 } else { // 如果是运算符,比较优先级并进行相应处理 while (!isEmpty(&stack) && getPriority(peek(&stack)) >= getPriority(current)) { postfixExpression[j++] = pop(&stack); } push(&stack, current); } } // 将栈中剩余的运算符输出到后缀表达式 while (!isEmpty(&stack)) { postfixExpression[j++] = pop(&stack); } // 添加字符串结束符 postfixExpression[j] = '\0'; } int main() { char infixExpression[100]; printf("Enter an infix expression: "); fgets(infixExpression, sizeof(infixExpression), stdin); // 假设后缀表达式不超过两倍的中缀表达式长度 char postfixExpression[2 * strlen(infixExpression)]; infixToPostfix(infixExpression, postfixExpression); printf("Postfix expression: %s\n", postfixExpression); return 0; }
这个程序使用了两个栈,一个用于运算符,一个用于操作数。通过遍历中缀表达式,根据运算符的优先级进行相应的处理,最终得到后缀表达式。程序输出转换后的后缀表达式。
答案和解析会在次日公布
注意事项
编写代码的时候,需要注意以下几点问题:
- 头文件的引用需要放在代码的最顶部
- 每个C语言程序中必须包含一个 main函数
- void main(){}
- int main(){return 0;}
- C语言中每一行的结尾处必须要使用分号结尾
- C语言中的引号需要使用双引号,双引号都是以一对一对的情况出现的
- 在scanf键盘输入代码中,要使用 & 加变量名来读取一个键盘输入
- 赋值语句是将右边的值赋给左边的变量,顺序不能反了
- 需要注意代码的缩进格式,缩进为4个空格或者一个tab键为一组,但是要保证整篇代码里面风格一致,要么都是4个空格缩进,要么都是使用一个tab进行缩进
- 需要养成随手保存的习惯,保存的快捷键一般是
ctrl + s
- 注意大括号的使用,大括号是代码块,代表了一个块的代码是放在一起的
- 注意整数型和实数型的转换,如果将实数赋值给一个整形变量,那么实数的小数部分将会被舍去;
- 注意除法中,如果除数和被除数都是整数,那么结果也会是一个整数,小数部分会自动舍弃
- 成对出现的标点符号
- 单引号,双引号,小括号,中括号,大括号等,一般不单独出现
- 如果代码有问题,然后附近又刚好有这些成对符号,请着重关注
- 定义变量时,该打的逗号应该打上,不能写掉了
- 编写++符号时,不要误写成了ff
- 一个程序里面只能有一个main函数,除了main函数的其他函数都不能叫这个名字
- 在调用函数时,入参都是使用的逗号隔开,一定不要使用分号隔开
- 换行符是
\n
,不能错误写成/n
- 输入输出格式化
%d
对应整数%c
对应字符%f
对应实数- 不要写错或者写漏了
- if条件语句当前行不能加分号,不然这个语句就没有意义了
- while语句和if语句一样,当行不能加分号
- 不建议使用goto语句,因为那样会造成程序结构的混乱,导致不可读
更多
欢迎来到C语言每日一练服务!
在现代技术的飞速发展中,编程已经成为一项不可或缺的技能。C语言作为一门经典的编程语言,奠定了计算机科学的基石,为学习其他编程语言打下了坚实的基础。为了帮助大家更好地掌握C语言,我们特别推出了每日一练服务,旨在提供系统性、全面性的学习支持。
我们的服务特点包括:
- 日常练习题目: 每天我们会提供一道C语言练习题目,涵盖基础知识、算法、数据结构等多个领域。这些题目既有难度,又具有实际应用价值,帮助你锻炼编程技能。
- 详细解析: 我们不仅提供每道题的标准答案,还会提供详细的解析和优秀代码示例。通过对解题思路的深入剖析,你能够更好地理解和掌握各种编程技巧。
- 互动学习社区: 通过微信文章评论区建立了一个互动学习社区,供学员们交流讨论。你可以在这里提问问题、分享经验,与其他学员一起成长。
- 个性化学习建议: 根据你的学习表现,我们会为你推荐相应难度的练习题,确保你的学习过程既具挑战性,又不至于过于困难,保持学习的动力和兴趣。
参与每日一练的好处:
- 持续学习提升技能: 每日坚持练习,你的编程技能将会得到持续提升,不断进步。
- 增强自信心: 通过解决各种类型的问题,你将建立起对自己技能的信心,更加轻松应对编程挑战。
- 拓宽思路: 每道题都是一个小挑战,通过解决这些问题,你将培养出灵活的思维,更好地应对实际编程工作中的挑战。
- 为未来发展奠定基础: 无论你是初学者还是有一定经验的程序员,C语言每日一练都将为你未来的编程发展奠定坚实的基础。
加入我们的C语言每日一练服务,一起挑战编程难题,不断提升自己,走向编程高手的道路!