C#实现栈
概述
先用C#实现一个栈的类,如下:
public class MyStack<T> : IEnumerable<T>, IDisposable
{
private int _top = ;
private int _size = ;
private T[] _stack = null; public int Top {
get {
return _top;
}
} public int Size {
get {
return _size;
}
} public int Length {
get {
return _top;
}
} public T this[int index] {
get {
return _stack[index];
}
} public MyStack(int size) {
_size = size;
_top = ;
_stack = new T[size];
} public bool IsEmpty() {
return _top == ;
} public bool IsFull() {
return _top == _size;
} public void Clear() {
_top = ;
} /// <summary>
/// 入栈
/// </summary>
/// <param name="node"></param>
/// <returns></returns>
public bool Push(T node) {
if (!IsFull()) {
_stack[_top] = node;
_top++;
return true;
}
return false;
} /// <summary>
/// 出栈
/// </summary>
/// <returns></returns>
public T Pop() {
T node = default(T);
if (!IsEmpty()) {
_top--;
node = _stack[_top];
}
return node;
} public void Traverse() {
for(int i = ; i < _top; i++) {
Console.WriteLine(_stack[i]);
}
} public IEnumerator<T> GetEnumerator() {
for(int i = ; i < _stack.Length; i++) {
if(_stack[i] != null) {
yield return _stack[i];
}
}
} IEnumerator IEnumerable.GetEnumerator() {
return GetEnumerator();
} public void Dispose() {
_stack = null;
}
}
上面要注意的是入栈时,是直接把值赋给栈顶,然后再将栈顶加1,出栈的时候,先将栈顶减一,再出栈,切记。
实例一:
用栈来实现进制转换,即十进制转化为2进制、8进制、16进制,代码如下:
/// <summary>
/// 十进制转换为其他进制
/// </summary>
/// <param name="number">要转换的数字</param>
/// <param name="target">目标进制</param>
/// <returns></returns>
public static string Process(int number, int target) {
string result = string.Empty;
string format = "0123456789ABCDEF";
MyStack<int> stack = new MyStack<int>();
int mod = ;
while(number != ) {
mod = number % target;
stack.Push(mod);
number = number / target;
}
while (!stack.IsEmpty()) {
int pos = stack.Pop();
result += format[pos];
}
return result;
}
测试代码:
string slt = MoronicConvert.Process(, );
Console.WriteLine(slt);
运行结果:
实例二
用栈来检查一个字符串括号是否配对,代码如下:
/// <summary>
/// 检查字符串中括号是否成对匹配
/// </summary>
/// <param name="charter">待检查的字符串</param>
/// <returns></returns>
public static bool Check(string charter) {
bool result = false;
MyStack<char> stack = new MyStack<char>();
MyStack<char> needStack = new MyStack<char>();
char currentNeed = '';
for (int i = ; i < charter.Length; i++) {
if(charter[i] != currentNeed) {
char t = charter[i];
stack.Push(t);
switch (t) {
case '[':
if(currentNeed != '') {
needStack.Push(currentNeed);
}
currentNeed = ']';
break;
case '(':
if(currentNeed != '') {
needStack.Push(currentNeed);
}
currentNeed = ')';
break;
case '{':
if (currentNeed != '') {
needStack.Push(currentNeed);
}
currentNeed = '}';
break;
}
}
else {
stack.Pop();
currentNeed = needStack.Pop();
}
}
if (stack.IsEmpty()) {
result = true;
}
return result;
}
测试代码:
bool check = SpellCheck.Check("[[([)]]]");
Console.WriteLine(check.ToString());
运行结果:
总结:
希望能帮到你,望推荐!
C#实现栈的更多相关文章
- 通往全栈工程师的捷径 —— react
腾讯Bugly特约作者: 左明 首先,我们来看看 React 在世界范围的热度趋势,下图是关键词“房价”和 “React” 在 Google Trends 上的搜索量对比,蓝色的是 React,红色的 ...
- Java 堆内存与栈内存异同(Java Heap Memory vs Stack Memory Difference)
--reference Java Heap Memory vs Stack Memory Difference 在数据结构中,堆和栈可以说是两种最基础的数据结构,而Java中的栈内存空间和堆内存空间有 ...
- duang~免费的学习视频来啦:学霸君之全栈测试
学霸君向童鞋们推荐一款 同名学霸学习 视频教程 重点是完全免费收看学习噢!!! 今天 学霸君推荐腾讯课堂的学霸君之全栈测试 复制下方链接至腾讯课堂中报名学习 https://ke.qq.com/cou ...
- [数据结构]——链表(list)、队列(queue)和栈(stack)
在前面几篇博文中曾经提到链表(list).队列(queue)和(stack),为了更加系统化,这里统一介绍着三种数据结构及相应实现. 1)链表 首先回想一下基本的数据类型,当需要存储多个相同类型的数据 ...
- BZOJ1012: [JSOI2008]最大数maxnumber [线段树 | 单调栈+二分]
1012: [JSOI2008]最大数maxnumber Time Limit: 3 Sec Memory Limit: 162 MBSubmit: 8748 Solved: 3835[Submi ...
- BZOJ 4453: cys就是要拿英魂![后缀数组 ST表 单调栈类似物]
4453: cys就是要拿英魂! Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 90 Solved: 46[Submit][Status][Discu ...
- BZOJ 3238: [Ahoi2013]差异 [后缀数组 单调栈]
3238: [Ahoi2013]差异 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 2326 Solved: 1054[Submit][Status ...
- .NET全栈开发工程师学习路径
PS:最近一直反复地看博客园以前发布的一条.NET全栈开发工程师的招聘启事,觉得这是我看过最有创意也最朴实的一个招聘启事,更为重要的是它更像是一个技术提纲,能够指引我们的学习和提升,现在转载过来与各位 ...
- Nodejs之MEAN栈开发(八)---- 用户认证与会话管理详解
用户认证与会话管理基本上是每个网站必备的一个功能.在Asp.net下做的比较多,大体的思路都是先根据用户提供的用户名和密码到数据库找到用户信息,然后校验,校验成功之后记住用户的姓名和相关信息,这个信息 ...
- 匹夫细说C#:不是“栈类型”的值类型,从生命周期聊存储位置
0x00 前言: 匹夫在日常和别人交流的时候,常常会发现一旦讨论涉及到“类型”,话题的热度就会立马升温,因为很多似是而非.或者片面的概念常常被人们当做是全面和正确的答案.加之最近在园子看到有人翻译的& ...
随机推荐
- OGR SQL
The OGRDataSource supports executing commands against a datasource via the OGRDataSource::ExecuteSQL ...
- Shell中的if else语句小演示
安安静静学习小shell,今天看到if else 喽~ 下面这个脚本是判断用户执行脚本的参数,如果是hello的话,就显示how are you 如果什么都没有,就提示输入 如果参数不是hello,就 ...
- HDU 4617Weapon(两条异面直线的距离)
Weapon Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) Total Sub ...
- 构件图(Component Diagram)—UML图(八)
构件图是显示代码自身结构的实现级别的图表.构件图由诸如源码文件.二进制代码文件.可运行文件或动态链接库 (DLL) 这种构件构成,并通过依赖关系相连接 以下这张图介绍了构件图的基本内容: 以下这张图是 ...
- java Native 方法
一. 什么是Native Method 简单地讲,一个Native Method就是一个java调用非java代码的接口.一个Native Method是这样一个java的方法:该方法的实现由非j ...
- Robot Framework与Web界面自动化测试学习笔记:利用xpath定位元素
在rf中,利用selinum2的关键字进行用例编写时,很多关键字的参数是html元素的定位标识. 最简单的方式,是通过id 或name来描述元素定位信息,如 click button id=l ...
- ORA-19815,ORA-19809 :limit exceeded for recovery files
数据库重新启动的时候,收到了ORA-19815的错误.从错误的提示来看,是由于闪回区的空间被填满导致无法成功启动.这种情形我们通常考虑的是清除归档日志,那就直接在OS层面rm了,真的是这样吗?客官,如 ...
- Laravel创建Model
它已被用于CI框架.最近学习使用Laravel框架,要总结一些遇到的问题是一个创纪录,供以后调用.此外,我希望能够碰到同样的问题的朋友的帮助. 在Laravel数据库表是根据Laravel写好的程序去 ...
- 遭遇“HTTP 错误 500.19 无法访问请求的页面,因为该页的相关配置数据无效。”
windows 2008下IIS7 安装ASP.NET 遇到如下错误: HTTP 错误 500.19 - Internal Server Error 无法访问请求的页面,因为该页的相关配置数据无效. ...
- 用c++开发基于tcp协议的文件上传功能
用c++开发基于tcp协议的文件上传功能 2005我正在一家游戏公司做程序员,当时一直在看<Windows网络编程> 这本书,把里面提到的每种IO模型都试了一次,强烈推荐学习网络编程的同学 ...