鱼C论坛

 找回密码
 立即注册
查看: 3335|回复: 5

大侠,帮忙看一下这个C++,帮我改正一下错误,我弄很久都解决不了

[复制链接]
发表于 2012-6-16 13:42:03 | 显示全部楼层 |阅读模式
1鱼币
#include <iostream>
using namespace std;
typedef struct
{
        char S[50]; /*用来存放栈中元素的一维数组*/
        int top;                          /*用来存放栈顶元素的下标,top为-1表示空栈*/
}SeqStack;

int main()
{
    char A[10];
        int Prool(char A[10],int n);
        int n;
        cin>>n;

        for(int i=0;i<n;i++)
        {
                cin>>A[i];
        }
        return 0;
}
int Prool(char A[10],int n)
{
    int top=-1;int i=0; int flag=1;         SeqStack S[50];
        while(i<n && flag)
        {
                if( A[i]=='(' || A[i]=='[' )
                        S[++top] = A[i++];
                else
                {
                        switch (A[i])
                        {
                        case ')':
                                if( top== -1 || S[top--] != '(') flag=0;
                                break;
                        case ']':
                                if( top== -1 || S[top--] != '[') flag=0;
                                break;
                        }
                }
                i++;
        }
        return flag;
}
\C++练习本\括号.cpp(28) : error C2679: binary '=' : no operator defined which takes a right-hand operand of type 'char' (or there is no acceptable conversion)
E:\C++练习本\括号.cpp(34) : error C2676: binary '!=' : 'SeqStack' does not define this operator or a conversion to a type acceptable to the predefined operator
E:\C++练习本\括号.cpp(37) : error C2676: binary '!=' : 'SeqStack' does not define this operator or a conversion to a type acceptable to the predefined operator
Error executing cl.exe.

括号.exe - 3 error(s), 0 warning(s)


最佳答案

查看完整内容

栈结构吧 首先 栈是一种特殊的链表 你要是学C++ 先做出个单向链表 然后继承就好了 自己添加个push pop方法 取链表的尾部和压入尾部 至于运算符重载 你的程序本身就有问题 SeqStack S[50]; S[++top] = A; S为SeqStack 数组 S[++top] 返回的是SeqStack 对象 右边为char类型 一个对象=一个char类型 即使重载了 你能告诉我做什么运算 你对象里也不是定义的char 而是char数组 完全可以在你结构体加一个 =号重 ...
小甲鱼最新课程 -> https://ilovefishc.com
发表于 2012-6-16 13:42:04 | 显示全部楼层
栈结构吧  首先 栈是一种特殊的链表
你要是学C++ 先做出个单向链表 然后继承就好了
自己添加个push pop方法 取链表的尾部和压入尾部
至于运算符重载

你的程序本身就有问题
SeqStack S[50];

S[++top] = A[i++];

S为SeqStack 数组
S[++top] 返回的是SeqStack 对象
右边为char类型
一个对象=一个char类型 即使重载了 你能告诉我做什么运算
你对象里也不是定义的char 而是char数组

完全可以在你结构体加一个 =号重载 和!=重载就可正确通过编译
我给你发下代码  重载里面没内容 实在写不了里面要干什么 程序本身就有问题 栈你的理解就是错误的
  1. #include "StdAfx.h"
  2. #include <iostream>
  3. using namespace std;
  4. struct SeqStack
  5. {
  6.         char S[50]; /*用来存放栈中元素的一维数组*/
  7.         int top;      
  8.         /*用来存放栈顶元素的下标,top为-1表示空栈*/
  9. public:
  10.     SeqStack& operator =(char ch)
  11.     {
  12.         //自己实现
  13.         return *this;
  14.         
  15.     }
  16.     bool   operator !=(char ch)
  17.     {
  18.         //自己实现
  19.         return true;
  20.     }
  21. };

  22. int main()
  23. {
  24.     char A[10];
  25.         int Prool(char A[10],int n);
  26.         int n;
  27.         cin>>n;

  28.         for(int i=0;i<n;i++)
  29.         {
  30.                 cin>>A[i];
  31.         }
  32.         return 0;
  33. }
  34. int Prool(char A[10],int n)
  35. {
  36.     int top=-1;int i=0; int flag=1;         SeqStack S[50];
  37.     while(i<n && flag)
  38.     {
  39.         if( A[i]=='(' || A[i]=='[' )
  40.             S[++top] = A[i++];
  41.         else
  42.         {
  43.             switch (A[i])
  44.             {
  45.             case ')':
  46.                 if( top== -1 || S[top--] != '(') flag=0;
  47.                 break;
  48.             case ']':
  49.                 if( top== -1 || S[top--] != '[') flag=0;
  50.                 break;
  51.             }
  52.         }
  53.         i++;
  54.     }
  55.     return flag;
  56. }
复制代码
数据结构要结合模板 栈要能存任何类型的

程序里定义的栈数组 实在没搞懂
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2012-6-16 15:10:00 | 显示全部楼层
一没重载【】二没重载=
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2012-6-16 16:38:55 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2012-6-16 23:38:48 | 显示全部楼层
ccqiji 发表于 2012-6-16 17:09
栈结构吧  首先 栈是一种特殊的链表
你要是学C++ 先做出个单向链表 然后继承就好了
自己添加个push pop方 ...

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

使用道具 举报

头像被屏蔽
发表于 2012-7-3 14:59:17 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-11-13 18:51

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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