C# Stack

Stack本质

Stack(栈)是一个C#为我们封装好的类

它的本质也是object[]数组,只是封装了特殊的存储规则

Stack是栈存储容器,栈是一种先进后出的数据结构

栈无法改变其中的元素 只能压(存)和弹(取)

实在要改 只有清空

申明

需要引用命名空间 System.Collections

Stack stack = new Stack();

压栈

stack.Push(1);

stack.Push("123");

stack.Push(true);

stack.Push(1.2f);

stack.Push(new Test());

出栈

object v = stack.Pop();

Console.WriteLine(v);

查看栈顶元素 查看元素是否存在

栈无法查看指定位置的 元素

只能查看栈顶的内容

v = stack.Peek();

Console.WriteLine(v);

v = stack.Peek();

Console.WriteLine(v);

查看元素是否存在于栈中

if( stack.Contains("123") )

{

Console.WriteLine("存在123");

}

遍历

1.长度

Console.WriteLine(stack.Count);

2.用foreach遍历

遍历出来的顺序 是从栈顶到栈底

foreach(object item in stack)

{

Console.WriteLine(item);

}

3.还有一种遍历方式

将栈转换为object数组

遍历出来的顺序 也是从栈顶到栈底

object[] array = stack.ToArray();

for (int i = 0; i < array.Length; i++)

{

Console.WriteLine(array[i]);

}

Console.WriteLine(stack.Count);

4.循环弹栈

while( stack.Count > 0 )

{

object o = stack.Pop();

Console.WriteLine(o);

}

Console.WriteLine(stack.Count);


cs 复制代码
class Program
{
    Stack stack = new Stack();
    public   static void Main()
    {
        Console.WriteLine("请输入10进制的正整数");
        int a;
       a=int.Parse( Console.ReadLine());
        Program program = new Program();
            program. To2Form(a);

         Console.Write("转换结果");
        while (program.stack.Count > 0)
        {
            Console.Write(program.stack.Pop());
        }

        
    }
    protected  void To2Form(int  a)
    {
        
        int y;
        while (a>=1) 
        {
            y=a % 2;
            a= a / 2;
            
            stack.Push(y);
        }

    }
}
相关推荐
小兔崽子去哪了2 小时前
Java 自动化部署
java·后端
ma_king2 小时前
入门 java 和 数据库
java·数据库·后端
后端AI实验室2 小时前
我用Cursor开发了3个月,整理出这套提效4倍的工作流
java·ai
用户298698530146 小时前
.NET 文档自动化:Spire.Doc 设置奇偶页页眉/页脚的最佳实践
后端·c#·.net
码路飞6 小时前
GPT-5.3 Instant 终于学会好好说话了,顺手对比了下同天发布的 Gemini 3.1 Flash-Lite
java·javascript
用户3667462526746 小时前
接口文档汇总 - 2.设备状态管理
c#
用户3667462526746 小时前
接口文档汇总 - 3.PLC通信管理
c#
SimonKing7 小时前
OpenCode AI编程助手如何添加Skills,优化项目!
java·后端·程序员
Seven978 小时前
剑指offer-80、⼆叉树中和为某⼀值的路径(二)
java
怒放吧德德19 小时前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty