C++三目运算符的问题
#include<iostream>#include<ctime>template<classT>structNode{Tdata;Node<T>*next;};temp...
#include<iostream>
#include<ctime>
template<class T>
struct Node
{
T data;
Node<T> *next;
};
template<class T>
class LinkQueue
{
public:
LinkQueue();/*构造函数,初始化一个空链表;*/
~LinkQueue();/*析构函数*/
void EnQueue(T x);/*入队操作,将x元素入队*/
T DeQueue();/*出队操作,将队头元素出队*/
T GetQueue(){return front->next->data ;}/*获取链队列的队头元素*/
void PrintList();//遍历整个链表
C2059-int Empty(){front==rear?return 1:return 0;}/*判断链队列是否为空*/
private:
Node<T> *front,*rear;/*队头队尾指针*/
};
//构造函数算法
template<class T>
LinkQueue<T>::LinkQueue()
{
Node<T> *s;
s=new Node<T>;
s->next=NULL;
front=rear=s;
}
//入队算法
template<class T>
void LinkQueue<T>::EnQueue(T x)
{
Node<T> *s;
s=new Node<T>;
s->data =x;
s->next=NULL;
rear->next =s;
rear=s;
}
//出队算法
template <class T>
T LinkQueue<T>::DeQueue()
{
if(rear==front) throw"下溢";
Node<T> *p;
int x;
p=front->next ;
x=p->data ;
front->next =p->next ;
if(p->next =NULL) rear=front;
delete p;
return x;
cout<<x;
}
//遍历
template <class T>
void LinkQueue<T>::PrintList()
{
Node<T> *p;
p=front->next ;
while (p!=0)
{
cout<<p->data ;
p=p->next ;
}
}
//析构函数算法
template <class T>
LinkQueue<T>::~LinkQueue ()
{
Node<T> *q;
while(front!=NULL)
{
q=front;
front=front->next;
delete q;
}
}
using namespace std;
void main()
{
int y;
LinkQueue<int> b;/*实例化一个对象b*/
b.EnQueue(3);//元素入队
b.EnQueue(4);
cout<<"\n"<<"判断队列是否为空:"<<endl;
int i=b.Empty();
if(i==1)
cout<<"队列为空"<<endl;
cout<<"队列非空";
}
调试后显示:c2059语法错误:return.
求解释!谢谢! 展开
#include<ctime>
template<class T>
struct Node
{
T data;
Node<T> *next;
};
template<class T>
class LinkQueue
{
public:
LinkQueue();/*构造函数,初始化一个空链表;*/
~LinkQueue();/*析构函数*/
void EnQueue(T x);/*入队操作,将x元素入队*/
T DeQueue();/*出队操作,将队头元素出队*/
T GetQueue(){return front->next->data ;}/*获取链队列的队头元素*/
void PrintList();//遍历整个链表
C2059-int Empty(){front==rear?return 1:return 0;}/*判断链队列是否为空*/
private:
Node<T> *front,*rear;/*队头队尾指针*/
};
//构造函数算法
template<class T>
LinkQueue<T>::LinkQueue()
{
Node<T> *s;
s=new Node<T>;
s->next=NULL;
front=rear=s;
}
//入队算法
template<class T>
void LinkQueue<T>::EnQueue(T x)
{
Node<T> *s;
s=new Node<T>;
s->data =x;
s->next=NULL;
rear->next =s;
rear=s;
}
//出队算法
template <class T>
T LinkQueue<T>::DeQueue()
{
if(rear==front) throw"下溢";
Node<T> *p;
int x;
p=front->next ;
x=p->data ;
front->next =p->next ;
if(p->next =NULL) rear=front;
delete p;
return x;
cout<<x;
}
//遍历
template <class T>
void LinkQueue<T>::PrintList()
{
Node<T> *p;
p=front->next ;
while (p!=0)
{
cout<<p->data ;
p=p->next ;
}
}
//析构函数算法
template <class T>
LinkQueue<T>::~LinkQueue ()
{
Node<T> *q;
while(front!=NULL)
{
q=front;
front=front->next;
delete q;
}
}
using namespace std;
void main()
{
int y;
LinkQueue<int> b;/*实例化一个对象b*/
b.EnQueue(3);//元素入队
b.EnQueue(4);
cout<<"\n"<<"判断队列是否为空:"<<endl;
int i=b.Empty();
if(i==1)
cout<<"队列为空"<<endl;
cout<<"队列非空";
}
调试后显示:c2059语法错误:return.
求解释!谢谢! 展开
2个回答
展开全部
函数的定义
<修饰符> <返回值类型> <函数名称>(参数列表)
c2059 并不是关键字,不能作为修饰符。
<修饰符> <返回值类型> <函数名称>(参数列表)
c2059 并不是关键字,不能作为修饰符。
追问
不是的c2059是调试时错误的所在行 具体的函数是 int Empty(){front==rear?return 1:return 0;}
你给改的只是把return 放在了前面 那么为什么我写的就不能运行呢?谢谢!
追答
三目运算符形式是
条件表达式? 表达式1:表达式2
三目运算表达式的值是表达式1或者表达式2的值。
关键字return XXX 是程序正常结束的语句,不是表达式,也就是没有结果值。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询