#include<iostream> #include<stack> #include<string> using namespace std; int main () { string A; string b,a; int temp1=0; int temp2=0; stack<string> stc; cin>>A; for(int i=0;i!=A.size();i++) { b=A.substr(i,1); stc.push(b); } for(int i=0;i!=stc.size();i++) { a=stc.top(); stc.pop(); if(a=="(") temp1++; if(a==")") temp2++; } if(temp1==temp2) { cout<<"true"; } else cout<<"false"; return 0; }以上代码有什么问题吗?
时间: 2024-03-25 11:42:05 浏览: 72
这段代码的问题在于第二个for循环的条件不正确。stack没有size()方法,需要用empty()方法来判断是否为空。正确的代码应该是:
```
for(int i=0;i!=A.size();i++)
{
b=A.substr(i,1);
stc.push(b);
}
while(!stc.empty())
{
a=stc.top();
stc.pop();
if(a=="(")
temp1++;
if(a==")")
temp2++;
}
```
另外,这段代码只是判断左右括号数量是否相等,并没有判断左右括号是否匹配,如果有多余的左括号或右括号也会输出true。
相关问题
#include<iostream> #include<cmath> #include<ctime> #include<cstdio> #include<fstream> #include<algorithm> #include<deque> #include<queue> #include<string> #include<map> #include<stack> #include<set> //#include<windows.h> using namespace std; int main() { int a[4][4],b[16]= { 0 } ,k=0; srand(time(0)); for (int i=0;i<4;i++) { for (int j=0;j<4;j++) { a[i][j]=rand()%10; if(a[i][j]%2==1) { b[k]=a[i][j]; ++k; } } } for (int i=0;i<k;++i) { cout<<b[i]<<" "; } return 0; }
这是一个 C++ 的程序,它生成一个 $4\times4$ 的矩阵 $a$,并将其中的奇数存入数组 $b$ 中,最后输出 $b$ 数组的内容。具体实现过程是:首先通过 `srand(time(0))` 函数初始化随机数种子,接着用 `rand()%10` 生成 $0$ 到 $9$ 之间的随机整数填充矩阵 $a$,如果矩阵中的元素是奇数,则将其存入数组 $b$ 中,最后依次输出 $b$ 数组中的元素。
在不使用任何STL容器的前提下实现这个代码#include <iostream> #include <memory> #include <stack> #include <fstream> #include <vector> #include <cmath> #include <iomanip> #include <exception> #include <climits> #include <array> #include <cstdint> #include <string> using namespace std; class T { public: virtual bool isOperator() = 0; virtual ~T() {} };
可以使用裸指针和自定义容器实现这段代码。
首先,我们需要定义一个自定义容器来存储T类型的指针。这个容器可以使用动态数组实现,需要自己管理内存。下面是一个简单的实现:
```c++
class MyVector {
public:
MyVector() : size_(0), capacity_(0), data_(nullptr) {}
~MyVector() {
clear();
delete[] data_;
}
void push_back(T* ptr) {
if (size_ == capacity_) {
reserve(capacity_ == 0 ? 1 : capacity_ * 2);
}
data_[size_++] = ptr;
}
void pop_back() {
if (size_ > 0) {
--size_;
}
}
T* back() const {
return size_ > 0 ? data_[size_ - 1] : nullptr;
}
bool empty() const {
return size_ == 0;
}
void clear() {
for (int i = 0; i < size_; ++i) {
delete data_[i];
}
size_ = 0;
}
private:
void reserve(int new_capacity) {
T** new_data = new T*[new_capacity];
for (int i = 0; i < size_; ++i) {
new_data[i] = data_[i];
}
delete[] data_;
data_ = new_data;
capacity_ = new_capacity;
}
int size_;
int capacity_;
T** data_;
};
```
接下来,我们需要定义一个栈,用来存储T类型的指针。这个栈可以使用动态数组实现,也需要自己管理内存。栈的基本操作包括push、pop、top等,可以按照以下方式实现:
```c++
class MyStack {
public:
MyStack() : size_(0), capacity_(0), data_(nullptr) {}
~MyStack() {
clear();
delete[] data_;
}
void push(T* ptr) {
if (size_ == capacity_) {
reserve(capacity_ == 0 ? 1 : capacity_ * 2);
}
data_[size_++] = ptr;
}
void pop() {
if (size_ > 0) {
--size_;
}
}
T* top() const {
return size_ > 0 ? data_[size_ - 1] : nullptr;
}
bool empty() const {
return size_ == 0;
}
void clear() {
for (int i = 0; i < size_; ++i) {
delete data_[i];
}
size_ = 0;
}
private:
void reserve(int new_capacity) {
T** new_data = new T*[new_capacity];
for (int i = 0; i < size_; ++i) {
new_data[i] = data_[i];
}
delete[] data_;
data_ = new_data;
capacity_ = new_capacity;
}
int size_;
int capacity_;
T** data_;
};
```
最后,我们可以定义一个派生自T的类,来实现isOperator()函数。这个函数在子类中可以根据实际需求来具体实现。
```c++
class MyT : public T {
public:
bool isOperator() override {
// 实现具体的逻辑
return false;
}
};
```
这样,就可以在不使用STL容器的前提下实现这个代码了。完整代码如下:
```c++
#include <iostream>
using namespace std;
class T {
public:
virtual bool isOperator() = 0;
virtual ~T() {}
};
class MyT : public T {
public:
bool isOperator() override {
// 实现具体的逻辑
return false;
}
};
class MyVector {
public:
MyVector() : size_(0), capacity_(0), data_(nullptr) {}
~MyVector() {
clear();
delete[] data_;
}
void push_back(T* ptr) {
if (size_ == capacity_) {
reserve(capacity_ == 0 ? 1 : capacity_ * 2);
}
data_[size_++] = ptr;
}
void pop_back() {
if (size_ > 0) {
--size_;
}
}
T* back() const {
return size_ > 0 ? data_[size_ - 1] : nullptr;
}
bool empty() const {
return size_ == 0;
}
void clear() {
for (int i = 0; i < size_; ++i) {
delete data_[i];
}
size_ = 0;
}
private:
void reserve(int new_capacity) {
T** new_data = new T*[new_capacity];
for (int i = 0; i < size_; ++i) {
new_data[i] = data_[i];
}
delete[] data_;
data_ = new_data;
capacity_ = new_capacity;
}
int size_;
int capacity_;
T** data_;
};
class MyStack {
public:
MyStack() : size_(0), capacity_(0), data_(nullptr) {}
~MyStack() {
clear();
delete[] data_;
}
void push(T* ptr) {
if (size_ == capacity_) {
reserve(capacity_ == 0 ? 1 : capacity_ * 2);
}
data_[size_++] = ptr;
}
void pop() {
if (size_ > 0) {
--size_;
}
}
T* top() const {
return size_ > 0 ? data_[size_ - 1] : nullptr;
}
bool empty() const {
return size_ == 0;
}
void clear() {
for (int i = 0; i < size_; ++i) {
delete data_[i];
}
size_ = 0;
}
private:
void reserve(int new_capacity) {
T** new_data = new T*[new_capacity];
for (int i = 0; i < size_; ++i) {
new_data[i] = data_[i];
}
delete[] data_;
data_ = new_data;
capacity_ = new_capacity;
}
int size_;
int capacity_;
T** data_;
};
int main() {
MyVector vec;
vec.push_back(new MyT());
vec.clear();
MyStack stk;
stk.push(new MyT());
stk.clear();
return 0;
}
```
阅读全文