欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

算法系列15天速成 第十天 棧

 更新時(shí)間:2013年11月15日 16:28:07   作者:  
今天跟大家聊聊棧,在程序設(shè)計(jì)中,棧的使用還是非常廣泛的,比如有“括號(hào)匹配問(wèn)題“,”html結(jié)構(gòu)匹配問(wèn)題“。所以說(shuō)掌握了”?!暗氖褂茫瑢?duì)我們學(xué)習(xí)算法還是很有幫助的


一: 概念

         棧,同樣是一種特殊的線性表,是一種Last In First Out(LIFO)的形式,現(xiàn)實(shí)中有很多這樣的例子,

     比如:食堂中的一疊盤(pán)子,我們只能從頂端一個(gè)一個(gè)的取。

 

二:存儲(chǔ)結(jié)構(gòu)

        ”?!安幌瘛标?duì)列“,需要兩個(gè)指針來(lái)維護(hù),棧只需要一個(gè)指針就夠了,這得益于棧是一種一端受限的線性表。

      這里同樣用”順序結(jié)構(gòu)“來(lái)存儲(chǔ)這個(gè)”?!?,top指針指向棧頂,所有的操作只能在top處。

         

代碼段:

復(fù)制代碼 代碼如下:

#region 棧的數(shù)據(jù)結(jié)構(gòu)
    /// <summary>
/// 棧的數(shù)據(jù)結(jié)構(gòu)
/// </summary>
    public class SeqStack<T>
    {
        public T[] data;

        /// <summary>
/// 棧頂指針
/// </summary>
        public int top = -1;

        public SeqStack(int lenth)
        {
            data = new T[lenth];
        }
    }
    #endregion


三:常用操作

        棧的操作有:①初始化棧,②入棧,③出棧,④獲取棧頂。

1: 初始化棧

        這個(gè)還是比較簡(jiǎn)單的,初始化棧時(shí),設(shè)置默認(rèn)top指針為-1,這個(gè)就不用圖來(lái)展示了。

代碼段:

復(fù)制代碼 代碼如下:

#region 棧的初始化操作
        /// <summary>
/// 棧的初始化操作
/// </summary>
/// <typeparam name="T"></typeparam>
/// <returns></returns>
        public SeqStack<T> SeqStackInit<T>(int length)
        {
            SeqStack<T> seqStack = new SeqStack<T>(length);

            seqStack.top = -1;

            return seqStack;
        }
        #endregion

2:入棧

       這個(gè)操作主要就是做兩件事情:① 將元素從棧頂壓入,② top指針自增。


代碼段:

復(fù)制代碼 代碼如下:

#region 入棧
        /// <summary>
/// 入棧
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="seqStack"></param>
/// <param name="data"></param>
        public void SeqStackPush<T>(SeqStack<T> seqStack, T data)
        {
            if (SeqStackIsFull(seqStack))
                throw new Exception("不好意思,棧溢出");

            seqStack.data[++seqStack.top] = data;
        }
        #endregion

3:出棧

      同樣跟“入?!鳖?lèi)似,需要做兩件事情,①干掉top處的元素,②top指針自減。

代碼段

復(fù)制代碼 代碼如下:

#region 出棧
        /// <summary>
/// 出棧
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="seqStack"></param>
/// <returns></returns>
        public T SeqStackPop<T>(SeqStack<T> seqStack)
        {
            if (SeqStackIsEmpty(seqStack))
                throw new Exception("嗚嗚,棧已空");

            seqStack.data[seqStack.top] = default(T);

            return seqStack.data[--seqStack.top];
        }
        #endregion

4:獲取棧頂元素

      這個(gè)很簡(jiǎn)單,跟“出?!蔽ㄒ徊煌氖遣黄茐臈m斣?,只是翻出來(lái)看看而已。

代碼段

復(fù)制代碼 代碼如下:

#region 獲取棧頂
        /// <summary>
/// 獲取棧頂
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="seqStack"></param>
/// <returns></returns>
        public T SeqStackPeek<T>(SeqStack<T> seqStack)
        {
            if (SeqStackIsEmpty(seqStack))
                throw new Exception("棧已空");

            return seqStack.data[seqStack.top];
        }
        #endregion

總的運(yùn)行代碼如下

復(fù)制代碼 代碼如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace SeqStack
{
    class Program
    {
        static void Main(string[] args)
        {
            SeqStackClass stackManager = new SeqStackClass();

            SeqStack<Student> seqStack = stackManager.SeqStackInit<Student>(10);

            Console.WriteLine("********************  壓入ID=1,ID=2,ID=3的元素  ***********************\n");
            //壓入ID=1,ID=2,ID=3的元素
            stackManager.SeqStackPush(seqStack, new Student() { ID = 1, Name = "一線碼農(nóng)", Age = 23 });
            stackManager.SeqStackPush(seqStack, new Student() { ID = 2, Name = "huangxincheng520", Age = 23 });
            stackManager.SeqStackPush(seqStack, new Student() { ID = 3, Name = "51cto", Age = 23 });

            Console.WriteLine(".... 壓入成功,當(dāng)前棧中元素有:" + stackManager.SeqStackLen(seqStack) + "個(gè)");

            Console.WriteLine("\n******************  查看棧頂元素  ********************");

            var result = stackManager.SeqStackPeek(seqStack);

            Console.WriteLine("棧頂元素為:ID=" + result.ID + ",Name=" + result.Name + ",Age=" + result.Age);

            Console.WriteLine("\n********************  彈出棧頂元素  ***********************");

            stackManager.SeqStackPop(seqStack);

            Console.WriteLine("\n******************  查看棧中的元素  ********************");

            for (int i = 0; i < stackManager.SeqStackLen(seqStack); i++)
            {
                Console.WriteLine("棧頂元素為:ID=" + seqStack.data[i].ID + ",Name=" + seqStack.data[i].Name + ",Age=" + seqStack.data[i].Age);
            }

            Console.Read();
        }
    }

    #region 學(xué)生數(shù)據(jù)實(shí)體
    /// <summary>
/// 學(xué)生數(shù)據(jù)實(shí)體
/// </summary>
    public class Student
    {
        public int ID { get; set; }

        public string Name { get; set; }

        public int Age { get; set; }
    }
    #endregion

    #region 棧的數(shù)據(jù)結(jié)構(gòu)
    /// <summary>
/// 棧的數(shù)據(jù)結(jié)構(gòu)
/// </summary>
    public class SeqStack<T>
    {
        public T[] data;

        /// <summary>
/// 棧頂指針
/// </summary>
        public int top = -1;

        public SeqStack(int lenth)
        {
            data = new T[lenth];
        }
    }
    #endregion

    public class SeqStackClass
    {
        #region 棧的初始化操作
        /// <summary>
/// 棧的初始化操作
/// </summary>
/// <typeparam name="T"></typeparam>
/// <returns></returns>
        public SeqStack<T> SeqStackInit<T>(int length)
        {
            SeqStack<T> seqStack = new SeqStack<T>(length);

            seqStack.top = -1;

            return seqStack;
        }
        #endregion

        #region 判斷棧是否為空
        /// <summary>
/// 判斷棧是否為空
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="seqStack"></param>
/// <returns></returns>
        public bool SeqStackIsEmpty<T>(SeqStack<T> seqStack)
        {
            return seqStack.top == -1;
        }
        #endregion

        #region 清空棧
        /// <summary>
/// 清空棧
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="seqStack"></param>
        public void SeqStackClear<T>(SeqStack<T> seqStack)
        {
            seqStack.top = -1;
        }
        #endregion

        #region 棧是否已滿(mǎn)
        /// <summary>
/// 棧是否已滿(mǎn)
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="seqStack"></param>
        public bool SeqStackIsFull<T>(SeqStack<T> seqStack)
        {
            return seqStack.top == seqStack.data.Length;
        }
        #endregion

        #region 入棧
        /// <summary>
/// 入棧
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="seqStack"></param>
/// <param name="data"></param>
        public void SeqStackPush<T>(SeqStack<T> seqStack, T data)
        {
            if (SeqStackIsFull(seqStack))
                throw new Exception("不好意思,棧溢出");

            seqStack.data[++seqStack.top] = data;
        }
        #endregion

        #region 出棧
        /// <summary>
/// 出棧
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="seqStack"></param>
/// <returns></returns>
        public T SeqStackPop<T>(SeqStack<T> seqStack)
        {
            if (SeqStackIsEmpty(seqStack))
                throw new Exception("嗚嗚,棧已空");

            seqStack.data[seqStack.top] = default(T);

            return seqStack.data[--seqStack.top];
        }
        #endregion

        #region 獲取棧頂
        /// <summary>
/// 獲取棧頂
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="seqStack"></param>
/// <returns></returns>
        public T SeqStackPeek<T>(SeqStack<T> seqStack)
        {
            if (SeqStackIsEmpty(seqStack))
                throw new Exception("棧已空");

            return seqStack.data[seqStack.top];
        }
        #endregion

        #region 獲取棧中元素個(gè)數(shù)
        /// <summary>
/// 獲取棧中元素個(gè)數(shù)
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="seqStack"></param>
/// <returns></returns>
        public int SeqStackLen<T>(SeqStack<T> seqStack)
        {
            return seqStack.top + 1;
        }
        #endregion
    }
}



相關(guān)文章

  • IntelliJ IDEA2020.3 新特性(小結(jié))

    IntelliJ IDEA2020.3 新特性(小結(jié))

    這篇文章主要介紹了IntelliJ IDEA 2020.3 新特性,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2020-12-12
  • 詳解HTTP協(xié)議簡(jiǎn)介

    詳解HTTP協(xié)議簡(jiǎn)介

    HTTP是訪問(wèn)互聯(lián)網(wǎng)使用的核心通信協(xié)議,也是所有web應(yīng)用程序使用的通信協(xié)議。下面通過(guò)本文給大家介紹HTTP協(xié)議簡(jiǎn)介的相關(guān)知識(shí),感興趣的朋友一起學(xué)習(xí)吧
    2018-01-01
  • Git中bundle命令的使用詳解

    Git中bundle命令的使用詳解

    這篇文章主要介紹了Git中bundle命令的使用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-08-08
  • 如何創(chuàng)建VS Code 擴(kuò)展插件

    如何創(chuàng)建VS Code 擴(kuò)展插件

    VS Code提供了強(qiáng)大的擴(kuò)展功能,本文主要介紹了如何創(chuàng)建VS Code 擴(kuò)展插件,主要包括插件的創(chuàng)建、開(kāi)發(fā)和發(fā)布過(guò)程,具有一定的參考價(jià)值,感興趣的可以了解一下
    2022-01-01
  • Web通信 分析工具 [推薦]

    Web通信 分析工具 [推薦]

    在抓蝦上看到一篇Web開(kāi)發(fā)分析工具的文章(鏈接就免了),怎么遠(yuǎn)沒(méi)有我用的東西好用呢? 還是介紹介紹我用的吧。由于平常開(kāi)發(fā)只用FireFox,完成后再去調(diào)試IE, 所以這些工具絕大部分是針對(duì)FireFox的。
    2009-04-04
  • Gitee的下載安裝配置及使用步驟詳解

    Gitee的下載安裝配置及使用步驟詳解

    這篇文章主要介紹了Gitee的下載安裝配置及使用,本文通過(guò)詳細(xì)步驟給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08
  • 利用git克隆歷史版本(下載指定版本的代碼)

    利用git克隆歷史版本(下載指定版本的代碼)

    這篇文章主要介紹了利用git克隆歷史版本(下載指定版本的代碼),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • 遇到不能復(fù)制的網(wǎng)站怎么辦?

    遇到不能復(fù)制的網(wǎng)站怎么辦?

    有時(shí)我們看到喜歡的網(wǎng)頁(yè)內(nèi)容時(shí)定會(huì)產(chǎn)生復(fù)制下來(lái)為我所用的沖動(dòng),不過(guò)當(dāng)你點(diǎn)擊鼠標(biāo)時(shí)它卻沒(méi)有任何反應(yīng),選擇的內(nèi)容沒(méi)有任何變化,不禁有點(diǎn)掃興。不要緊,辦法總比困難多!
    2009-06-06
  • Git科普文,Git基本原理及各種騷操作(推薦)

    Git科普文,Git基本原理及各種騷操作(推薦)

    這篇文章主要介紹了Git科普文,Git基本原理及各種騷操作,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08
  • udp協(xié)議簡(jiǎn)介_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    udp協(xié)議簡(jiǎn)介_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    這篇文章主要為大家詳細(xì)介紹了udp協(xié)議簡(jiǎn)介的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07

最新評(píng)論