鱼C论坛

 找回密码
 立即注册
查看: 3596|回复: 3

关于用栈 求回文的程序

[复制链接]
发表于 2013-4-20 19:16:18 | 显示全部楼层 |阅读模式
5鱼币
本帖最后由 芊芊 于 2013-4-20 19:25 编辑

我想用 入栈 出栈的方法 去求回文。1.将入栈的 字符存放在数组a 中 然后 入栈 直到输入的字符是@ 为止。
2.然后 出栈 将元素存放在数组b中。(b 应该是颠倒的 字符串)
3.最后比较数组a 和 数组 b 看两者是否相同。


为何程序不对呢?  哪位鱼粉 指点指点{:7_169:}
  1. #include<iostream.h>
  2. #define MaxSize 20
  3. #define Flag 0
  4. typedef struct Node{
  5.         int date[MaxSize];
  6.         int top;
  7. }SeqStack;

  8. /********初始化栈************/
  9. SeqStack *Init_SeqStack()
  10. {
  11.         SeqStack *s;
  12.         s = new SeqStack;
  13.         if(!s)
  14.                 return NULL;
  15.         else{
  16.                 s -> top = -1;
  17.                 return s;
  18.         }
  19. }

  20. /*************入栈*************/
  21. int Push_SeqStack(SeqStack *s, char x)
  22. {
  23.         if(s -> top == MaxSize -1)
  24.                 return 0;
  25.                 else
  26.                 {
  27.                         s -> top++;
  28.                         s -> date[s -> top] = x;
  29.                         return 1;                        
  30.                 }        
  31. }

  32. /************出栈取栈顶元素**************/
  33. char Pop_SeqStack(SeqStack *s)
  34. {
  35.         char x;
  36.         x = s -> date[s -> top];
  37.         s -> top --;
  38.         return x;
  39. }
  40. void main()
  41. {
  42.         char c, a[MaxSize], b[MaxSize];
  43.         int i = 0,  j;

  44.         SeqStack *s;
  45.         s = Init_SeqStack();
  46.         cin >> c;
  47.         while(c != 0)
  48.         {
  49.                 a[i] = c;
  50.                 Push_SeqStack(s, c);        
  51.                 i++;
复制代码


最佳答案

查看完整内容

然后么- -额 - - 这代码有些不论不类- -看来你们老师的C++学的有点.... struct在C++中- -不用typedef就可以定义出来了 而且 - -毫无封装性,用的C式写法- -,连参数也不知道可以用引用类型 缺少内存回收的函数- - 好吧- -以上不是重点 出栈没有考虑栈空 第51行代码不是判断@ 代码不完整
小甲鱼最新课程 -> https://ilovefishc.com
发表于 2013-4-20 19:16:19 | 显示全部楼层
然后么- -额 - -
这代码有些不论不类- -看来你们老师的C++学的有点....
struct在C++中- -不用typedef就可以定义出来了
而且 - -毫无封装性,用的C式写法- -,连参数也不知道可以用引用类型
缺少内存回收的函数- -

好吧- -以上不是重点
出栈没有考虑栈空
第51行代码不是判断@
代码不完整

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2013-4-20 19:32:05 | 显示全部楼层
= =这个么- -
  1. #include <stdio.h>
  2. int main(void){
  3.         char ch = getchar();
  4.         if(ch != '@'){
  5.                 main();
  6.                 putchar(ch);
  7.         }
  8. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2013-4-20 19:33:17 | 显示全部楼层
这个代码也是用栈哟
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-8-2 10:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表