C 语言:用顺序栈基本运算判断字符串是否为回文的完整代码实现
以下是使用 C 语言编写的利用顺序栈判断一个字符串是否为回文的代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_SIZE 100 // 定义顺序栈结构体 typedef struct { char data[MAX_SIZE]; int top; } Stack; // 初始化栈 void initStack(Stack *s) { s->top = -1; } // 判断栈是否为空 int isEmpty(Stack *s) { return s->top == -1; } // 判断栈是否已满 int isFull(Stack *s) { return s->top == MAX_SIZE - 1; } // 入栈 void push(Stack *s, char c) { if (!isFull(s)) { s->data[++s->top] = c; } else { printf("Stack is full!\n"); } } // 出栈 char pop(Stack *s) { if (!isEmpty(s)) { return s->data[s->top--]; } else { printf("Stack is empty!\n"); return '\0'; } } // 判断字符串是否为回文 int isPalindrome(char *str) { Stack s; initStack(&s); int len = strlen(str); int mid = len / 2; for (int i = 0; i < mid; i++) { push(&s, str[i]); } if (len % 2!= 0) { mid++; } for (int i = mid; i < len; i++) { if (pop(&s)!= str[i]) { return 0; } } return 1; } int main() { char str[] = "race a car"; if (isPalindrome(str)) { printf("%s 是回文\n", str); } else { printf("%s 不是回文\n", str); } return 0; } ``` 这段代码首先定义了一个顺序栈的数据结构,然后实现了相关的操作函数。`isPalindrome`函数通过将字符串前半部分入栈,然后与后半部分依次比较来判断是否为回文。 ######[AI写代码神器 | 548点数解答 | 2024-10-24 11:35:05]
- C++ 求解:最少操作次数让字符串无子串 “friend” (字节豆包 | 153点数解答 | 2024-08-17 16:29:54)499
- C++ 求解:最少操作次数让字符串不再含 “friend” 子串!(讯飞星火 | 260点数解答 | 2024-08-17 16:30:49)483
- Python 巧解:最少操作次数让字符串告别“friend”子串(字节豆包 | 139点数解答 | 2024-08-18 13:04:14)426
- 3414 数字游戏:Python 求解 8 位 01 字符串中 1 的个数 (字节豆包 | 106点数解答 | 2024-10-27 14:23:27)446
- 巧用字符添加,计算字符串中“our”最大数量及开发注意要点(DeepSeek | 376点数解答 | 2025-10-30 19:20:06)96
- C 语言实现:处理字符串生成最多 “our” 串,附代码及关键开发注意点 (DeepSeek | 257点数解答 | 2025-10-30 19:20:36)129
- 重新定义字母大小关系:让 “L 队” 字典序小于 “某 E” 的代码实现与分析(字节豆包 | 595点数解答 | 2025-12-03 19:44:59)83
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)380
- Python 函数:如何高效检测字符串是否为回文,注意这些逻辑点!(字节豆包 | 151点数解答 | 2024-11-21 13:18:49)153
- Python 实现:超详细回文检测函数,处理空格标点、空串与递归边界!(字节豆包 | 244点数解答 | 2024-11-21 13:21:58)162
- C++ 实现我的世界基岩版:从简单框架到开发要点揭秘(字节豆包 | 182点数解答 | 2025-02-22 15:53:11)214
- “才女”技能揭秘:用牌时可跨类型出牌!(字节豆包 | 43点数解答 | 2025-07-31 10:26:35)192