gpt4 book ai didi

c++ - "top"值不会改变我推送或弹出堆栈的次数

转载 作者:太空宇宙 更新时间:2023-11-04 12:32:40 24 4
gpt4 key购买 nike

我正在使用动态数组实现堆栈。我的想法很简单:我希望用户输入他/她想要的长度,然后创建一个具有该长度的堆栈。然后他/她可以推送,弹出一个整数;查看最高值和最大值(用于调试目的);检查它是满的还是空的(也用于调试)。他/她可以插入直到堆栈已满然后必须弹出,他/她可以弹出直到堆栈为空然后必须插入。我使用 do while 和 switch 来简化调试和操作。但是当我开始测试时,我的 Stack 类的最高属性在我推送或弹出的次数中仍然为 0。我一直在努力寻找错误,但仍然没有找到。

这是我的代码:

#include <cstdio>
#include <iostream>

using std::cin;
using std::cout;
using std::endl;

class Stack {
int top;
int max; // max index
int *data;
public:
Stack(int length);
int isEmpty();
int isFull();
int push(int n);
int pop();
int getTop(void);
int getMax(void);
~Stack(void);
};

Stack::Stack(int length){
top = 0;
max = length;
data = new int[length+1];
}
int Stack::isEmpty(void){
return top==0;
}
int Stack::isFull(void){
return top==max;
}
int Stack::push(int n){
if(!isFull()){
data[++top] = n;
return 1;
}
else return 0;

}
int Stack::pop(void){
if(!isEmpty()){
return data[top--];
}
else return -911; //rare and indicative number
}
int Stack::getTop(void){
return top;
}
int Stack::getMax(void){
return max;
}
Stack::~Stack(void){
delete[] data;
}

int main(void){
int length = 0;
cout << "Enter stack's length': "; cin >> length;
Stack list(length);
char lock;
do{
cout << "1. push" << endl;
cout << "2. pop" << endl;
cout << "3. show top index" << endl;
cout << "4. show max index" << endl;
cout << "5. isFull?" << endl;
cout << "6. isEmpty?" << endl;
cout << "0. Quit" << endl;
scanf("%d", &lock);
switch(lock){
case 1:
int temp;
cout << "Enter an integer: ";
cin >> temp;
printf(list.push(temp)?"success\n":"fail\n");
break;
case 2:
cout << "Top's data: " << list.pop() << endl;
break;
case 3:
cout << list.getTop() << endl;
break;
case 4:
cout << list.getMax() << endl;
break;
case 5:
printf(list.isFull()?"True\n":"False\n");
break;
case 6:
printf(list.isEmpty()?"True\n":"False\n");
break;
case 0: break;
default:
cout << "Not an available work!" << endl;
}
} while (lock!= 0);

return 0;
}

最佳答案

您有细微的内存损坏。原因:

q58036810.cpp:71:21: warning: format specifies type 'int *' but the argument has type 'char *' [-Wformat]
scanf("%d", &lock);
~~ ^~~~~
%s

当您在菜单中输入数字时,它对于 lock 来说太大了,因此覆盖了 list 中存储 top 的内存>。将 char lock 更改为 int lock,问题就会消失。以后,总是带着警告编译并注意它们。此外,根据这个问题的性质,它不会始终如一地重现(即,它似乎在我的机器上运行良好。)

关于c++ - "top"值不会改变我推送或弹出堆栈的次数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58036810/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com