C(或C++)实现顺序栈,并利用该栈实现教材的数制转换算法。
时间: 2024-10-22 12:09:37 浏览: 44
在C或C++中,我们可以使用数组或动态内存分配来实现一个基本的顺序栈(也称为简单堆栈)。这里我们选择数组作为基础实现:
```c++
#include <iostream>
const size_t MAX_SIZE = 100; // 栈的最大容量
// 定义顺序栈
template<typename T>
class SequentialStack {
private:
T stack[MAX_SIZE];
size_t top; // 栈顶指针
public:
SequentialStack() { top = -1; } // 初始化为空
// 判断栈是否为空
bool isEmpty() const { return top == - 1) {
std::cout << "Stack overflow!\n";
return;
}
stack[++top] = item;
}
// 弹出并返回栈顶元素
T pop() {
if (isEmpty()) {
std::cout << "Stack underflow!\n";
return T();
}
return stack[top--];
}
// 查看栈顶元素但不弹出
T peek() const {
if (isEmpty()) return T();
return stack[top];
}
};
// 数制转换算法示例:将十进制整数转换成其他进制
void convertNumberToBase(int decimal, int base, SequentialStack<char>& digits) {
while (decimal > 0) {
digits.push((decimal % base) + '0'); // 加上字符'0'
decimal /= base;
}
}
int main() {
int decimal = 12345;
SequentialStack<char> digits;
convertNumberToBase(decimal, 2, digits); // 十进制转二进制
std::cout << "Binary: ";
while (!digits.isEmpty()) {
std::cout << digits.pop();
}
std::cout << "\n";
// 更改base参数进行其他进制转换
digits.clear(); // 清除栈
convertNumberToBase(decimal, 8, digits); // 十进制转八进制
std::cout << "Octal: ";
while (!digits.isEmpty()) {
std::cout << digits.pop();
}
std::cout << "\n";
return 0;
}
```
上述代码首先定义了一个顺序栈`SequentialStack`模板,用于存储字符。接着,`convertNumberToBase`函数通过不断取余法将十进制数转换为相应基数的数字,并将它们压入栈中。在`main`函数里,我们展示了将12345分别转换为二进制和八进制的过程。
阅读全文