news 2026/6/23 2:11:54

7.抽象数据类型

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
7.抽象数据类型

7.抽象数据类型

栈由可对它执行的操作来描述:

1、可创建空栈;

2、可将数据项添加到栈顶;

3、可从栈顶删除数据项;

4、可查看栈是否填满;

5、可查看栈是否为空。

将上述描述转换为一个类声明,公有成员函数提供了表示栈操作的接口,私有数据成员负责存储栈数据。

设计一个栈,让它可以存放不同的数据类型,

typedef给类型起别名,以存放不同的数据类型,只需要在这里改就行。

stack.h

#pragma once #ifndef __STACK_H__ #define __STACK_H__ typedef unsigned long Items;//让栈可以存放不同的数据类型,只需要在这里改就行 class Stack { private: static const int MAX = 10; int top;//栈顶指针 Items items[MAX]; public: Stack(); //构造函数,初始化栈顶指针为-1 bool isEmpty() const; //判断栈是否为空 bool isFull() const; //判断栈是否已满 bool push(Items &a); //入栈 bool pop(Items &a); //出栈 }; #endif ​

.

stack.cpp

#include "stack.h" Stack::Stack() { top = 0; // 初始化栈顶指针为0,表示栈为空 } bool Stack::isEmpty() const { if (top == 0) { return true; // 栈为空 } else return false; // 栈非空 } bool Stack::isFull() const { if (top == MAX) { return true; // 栈已满 } else { return false; // 栈未满 } } bool Stack::push(Items& a) { if (top < MAX) { items[top++] = a; // 将元素a压入栈顶 return true; // 入栈成功 } else { return false; // 栈已满,入栈失败 } } bool Stack::pop(Items& a) { if (top > 0) { a = items[--top]; // 将栈顶元素赋值给a return true; } else { return false; // 栈为空,出栈失败 } }

.

project1.cpp

// project1.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。 // ​ #include <iostream> #include "stack.h" #include <cstdlib> #include <string> using namespace std; int main() { std::cout << "Hello World!\n"; char ch; unsigned long a; // 定义一个无符号长整型变量 a Stack stack; // 创建栈对象 //cin >> ch; // 输入字符 ch; cout << "enter A to push to stack,\n" << "P to pop from stack, Q to quit.\n" << endl; while (cin >> ch && toupper(ch) != 'Q') { while (cin.get() != '\n') continue; switch (ch) { case 'A': case 'a': { cout << "Enter a character to push onto the stack: " << endl; cin >> a; // 输入要入栈的字符 if (stack.isFull()) { cout << "stack is already full" << endl; } else { stack.push(a); // 将字符入栈 } break; } case 'p': case 'P': { if (stack.isEmpty()) { cout << "stack is empty" << endl; } else { stack.pop(a); // 将栈顶元素出栈 cout << "poped item is: " << a << endl; // 输出出栈的元素 } break; } } } ​ } ​ // 运行程序: Ctrl + F5 或调试 >“开始执行(不调试)”菜单 // 调试程序: F5 或调试 >“开始调试”菜单 ​ // 入门使用技巧: // 1. 使用解决方案资源管理器窗口添加/管理文件 // 2. 使用团队资源管理器窗口连接到源代码管理 // 3. 使用输出窗口查看生成输出和其他消息 // 4. 使用错误列表窗口查看错误 // 5. 转到“项目”>“添加新项”以创建新的代码文件,或转到“项目”>“添加现有项”以将现有代码文件添加到项目 // 6. 将来,若要再次打开此项目,请转到“文件”>“打开”>“项目”并选择 .sln 文件 ​

00

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 21:26:49

1.运算符重载

1.运算符重载函数重载&#xff0c;函数们在执行相同的操作&#xff0c;但是操作的对象的数据类型不同。运算符重载允许赋予C运算符多种含义。C根据操作数的数目和类型来决定采用哪种操作。例如&#xff1a;两个数组相加。正常来说要&#xff1a;for(ing i 0; i < 20; i) {s…

作者头像 李华
网站建设 2026/6/23 4:58:24

照明系统设计

照明系统设计学习指南&#xff1a;从基础到实践照明系统设计是光学设计的重要分支&#xff0c;核心是通过光学手段实现特定光分布、光效与光质目标&#xff0c;广泛应用于LED照明、汽车灯光、显示屏背光、舞台灯光等场景。以下是针对性的学习框架与实践路径。一、核心知识体系&…

作者头像 李华
网站建设 2026/6/23 1:43:56

GPT-5.2 震撼发布:知识型工作超越人类专家的 AI 生产力革命!

点击下方“JavaEdge”&#xff0c;选择“设为星标”第一时间关注技术干货&#xff01;本文已收录在Github&#xff0c;关注我&#xff0c;紧跟本系列专栏文章&#xff0c;咱们下篇再续&#xff01;&#x1f680; 魔都架构师 | 全网30W技术追随者&#x1f527; 大厂分布式系统/数…

作者头像 李华
网站建设 2026/6/23 9:02:38

这些CTF,不仅学技术,还有巨额奖金!

前言&#xff1a; 不会吧&#xff0c;不会吧&#xff0c;不会还有安全er不知道CTF是什么吧&#xff1f; 在程序员的世界里&#xff0c;也有ACM这样的编程大赛&#xff0c;成为各路编程高手一较高下展示能力的平台。 那在网络安全的圈子里&#xff0c;各路黑客红客白帽子们又…

作者头像 李华
网站建设 2026/6/22 19:06:28

5个必学技巧!让你的点云可视化性能提升200%

5个必学技巧&#xff01;让你的点云可视化性能提升200% 【免费下载链接】rerun Visualize streams of multimodal data. Fast, easy to use, and simple to integrate. Built in Rust using egui. 项目地址: https://gitcode.com/GitHub_Trending/re/rerun 你是否在加载…

作者头像 李华
网站建设 2026/6/23 18:35:44

轻量级图表库uPlot完全指南:解锁高性能可视化新境界

轻量级图表库uPlot完全指南&#xff1a;解锁高性能可视化新境界 【免费下载链接】uPlot &#x1f4c8; A small, fast chart for time series, lines, areas, ohlc & bars 项目地址: https://gitcode.com/gh_mirrors/up/uPlot 想要在网页中流畅展示大量时间序列数据…

作者头像 李华