校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 算法系列15天速成 第十天 棧

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

熱門標(biāo)簽:電銷機(jī)器人怎么收費(fèi) 嘟聲的電銷機(jī)器人 地圖標(biāo)注和圖片標(biāo)注 滄州智能外呼系統(tǒng)收費(fèi) 醫(yī)院地圖標(biāo)注 語音平臺系統(tǒng) 忻州外呼系統(tǒng)接口對接 洛陽便宜外呼系統(tǒng)廠家 湖北穩(wěn)定外呼系統(tǒng)


一: 概念

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

     比如:食堂中的一疊盤子,我們只能從頂端一個一個的取。

 

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

        ”棧“不像”隊列“,需要兩個指針來維護(hù),棧只需要一個指針就夠了,這得益于棧是一種一端受限的線性表。

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

         

代碼段:

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

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

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

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


三:常用操作

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

1: 初始化棧

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

代碼段:

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

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

            seqStack.top = -1;

            return seqStack;
        }
        #endregion

2:入棧

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


代碼段:

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

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

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

3:出棧

      同樣跟“入棧”類似,需要做兩件事情,①干掉top處的元素,②top指針自減。

代碼段

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

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

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

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

4:獲取棧頂元素

      這個很簡單,跟“出棧”唯一不同的是不破壞棧頂元素,只是翻出來看看而已。

代碼段

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

#region 獲取棧頂
        /// summary>
/// 獲取棧頂
/// /summary>
/// typeparam name="T">/typeparam>
/// param name="seqStack">/param>
/// returns>/returns>
        public T SeqStackPeekT>(SeqStackT> 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();

            SeqStackStudent> seqStack = stackManager.SeqStackInitStudent>(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) + "個");

            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 SeqStackT>
    {
        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 SeqStackT> SeqStackInitT>(int length)
        {
            SeqStackT> seqStack = new SeqStackT>(length);

            seqStack.top = -1;

            return seqStack;
        }
        #endregion

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

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

        #region 棧是否已滿
        /// summary>
/// 棧是否已滿
/// /summary>
/// typeparam name="T">/typeparam>
/// param name="seqStack">/param>
        public bool SeqStackIsFullT>(SeqStackT> 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 SeqStackPushT>(SeqStackT> 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 SeqStackPopT>(SeqStackT> 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 SeqStackPeekT>(SeqStackT> seqStack)
        {
            if (SeqStackIsEmpty(seqStack))
                throw new Exception("棧已空");

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

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



您可能感興趣的文章:
  • 算法系列15天速成 第十四天 圖【上】
  • 算法系列15天速成——第十三天 樹操作【下】
  • 算法系列15天速成 第十二天 樹操作【中】
  • 算法系列15天速成 第十一天 樹操作(上)
  • 算法系列15天速成 第八天 線性表【下】
  • 算法系列15天速成 第九天 隊列
  • 算法系列15天速成 第七天 線性表【上】
  • 算法系列15天速成 第六天 五大經(jīng)典查找【下】
  • 算法系列15天速成 第五天 五大經(jīng)典查找【中】
  • 算法系列15天速成 第四天 五大經(jīng)典查找【上】
  • 算法系列15天速成 第三天 七大經(jīng)典排序【下】
  • 算法系列15天速成 第二天 七大經(jīng)典排序【中】
  • 算法系列15天速成 第一天 七大經(jīng)典排序【上】
  • 算法系列15天速成——第十五天 圖【下】(大結(jié)局)

標(biāo)簽:內(nèi)蒙古 日照 宜賓 定州 防城港 96 巴彥淖爾 山南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《算法系列15天速成 第十天 棧》,本文關(guān)鍵詞  算法,系列,15天,速成,第,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《算法系列15天速成 第十天 棧》相關(guān)的同類信息!
  • 本頁收集關(guān)于算法系列15天速成 第十天 棧的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    99视频一区二区| 国产精品久久久久影院| 中文字幕欧美激情一区| 亚洲动漫第一页| 成人在线一区二区三区| 欧美一卡二卡在线观看| 日韩美女视频一区| 国产成+人+日韩+欧美+亚洲| 欧美一区二区三区不卡| 亚洲一区二区三区免费视频| 99视频超级精品| 国产日韩欧美亚洲| 裸体一区二区三区| 欧美精品在线一区二区三区| 亚洲女人的天堂| 成人自拍视频在线| 中文字幕不卡三区| 国产成人精品免费| 久久精子c满五个校花| 美女一区二区久久| 欧美一三区三区四区免费在线看| 亚洲在线成人精品| 欧美中文字幕一区二区三区亚洲 | 福利视频网站一区二区三区| 日韩女优电影在线观看| 日本不卡一二三| 欧美一区二区视频在线观看2022| 亚瑟在线精品视频| 欧美夫妻性生活| 日韩av网站在线观看| 69堂亚洲精品首页| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美另类一区二区三区| 婷婷一区二区三区| 日韩午夜av电影| 精品亚洲免费视频| 日本一区二区动态图| 91免费版pro下载短视频| 亚洲精品国久久99热| 欧美日韩三级一区| 麻豆精品视频在线观看视频| 精品剧情v国产在线观看在线| 狠狠久久亚洲欧美| 国产欧美精品区一区二区三区| 成人国产视频在线观看| 亚洲私人影院在线观看| 91国内精品野花午夜精品| 日韩高清在线观看| 久久久不卡网国产精品二区| 99视频精品在线| 日一区二区三区| 久久嫩草精品久久久精品一| 精品视频在线视频| 亚洲超碰精品一区二区| 亚洲精品一区二区三区香蕉| 国产超碰在线一区| 亚洲图片欧美一区| 精品人在线二区三区| 99久久精品国产一区二区三区| 亚洲国产成人91porn| 久久久精品天堂| 在线观看国产91| 韩国精品久久久| 亚洲欧洲综合另类| 精品乱人伦小说| 色一情一乱一乱一91av| 韩国精品一区二区| 亚洲国产日韩精品| 日本一区二区三区dvd视频在线| 色婷婷久久综合| 国产在线麻豆精品观看| 亚洲综合色区另类av| www国产成人| 欧美日韩国产在线观看| 高清成人在线观看| 日韩高清不卡在线| 一区在线中文字幕| 精品久久国产老人久久综合| 欧美在线观看一区| 成人动漫一区二区三区| 久久精品国产亚洲高清剧情介绍| 一区二区三区91| 国产精品嫩草影院av蜜臀| 日韩一区二区不卡| 欧美日韩精品久久久| 91在线视频免费91| 国产高清精品网站| 久久精品噜噜噜成人av农村| 亚洲免费av观看| 一色屋精品亚洲香蕉网站| 精品国产乱码久久久久久久久| 欧美日韩高清一区二区不卡| 色综合一个色综合亚洲| 成人丝袜18视频在线观看| 国内偷窥港台综合视频在线播放| 香蕉成人啪国产精品视频综合网| 亚洲人妖av一区二区| 国产精品乱码妇女bbbb| 精品国产a毛片| 日韩三级电影网址| 日韩欧美的一区| 欧美一区二区视频在线观看2020 | 在线视频一区二区三| 不卡一二三区首页| 国产成人午夜电影网| 精品一区二区三区免费播放| 蜜臀av一区二区三区| 免费av网站大全久久| 日本最新不卡在线| 日韩精品1区2区3区| 青青国产91久久久久久| 日韩成人一级片| 免费xxxx性欧美18vr| 免费视频最近日韩| 激情五月激情综合网| 久久99久久久欧美国产| 蜜乳av一区二区三区| 日本亚洲视频在线| 激情综合色综合久久| 国内精品免费**视频| 国产高清精品网站| 不卡一区二区三区四区| 91在线视频官网| 欧美日本高清视频在线观看| 欧美一区二区视频在线观看 | 播五月开心婷婷综合| 暴力调教一区二区三区| 99久久久精品| 欧美性一区二区| 日韩欧美成人激情| 欧美激情在线一区二区三区| 一色屋精品亚洲香蕉网站| 一级特黄大欧美久久久| 日本亚洲电影天堂| 国产麻豆精品theporn| 成人美女在线观看| 欧美午夜精品一区| 久久综合国产精品| 亚洲美女一区二区三区| 日韩国产欧美视频| 国产一区二区三区四区五区入口| 成人动漫一区二区三区| 欧美日韩一区高清| 26uuu欧美| 亚洲精品ww久久久久久p站| 日韩精彩视频在线观看| 国产成人精品一区二| 色噜噜狠狠成人网p站| 日韩美女一区二区三区四区| 国产精品欧美久久久久一区二区| 亚洲狠狠爱一区二区三区| 国产自产视频一区二区三区| 在线观看国产一区二区| 久久精品亚洲国产奇米99| 一区二区成人在线视频| 国产老妇另类xxxxx| 在线观看不卡一区| 国产无一区二区| 日韩电影在线看| 91老师国产黑色丝袜在线| 日韩午夜激情免费电影| 有坂深雪av一区二区精品| 国产成人自拍网| 91麻豆精品国产综合久久久久久| 国产精品另类一区| 黄页视频在线91| 欧美高清视频在线高清观看mv色露露十八| 久久久久99精品一区| 视频一区视频二区中文字幕| 99麻豆久久久国产精品免费 | 欧美精品在线一区二区| 亚洲人成网站影音先锋播放| 国产一区二区三区观看| 在线电影一区二区三区| 亚洲永久精品大片| 99re视频精品| 日本一区二区三区四区| 国产一区二区美女诱惑| 欧美一级夜夜爽| 亚洲一区二区三区视频在线播放| 99国产精品久久久久久久久久 | 成人高清视频在线观看| 久久色.com| 国模大尺度一区二区三区| 日韩欧美123| 日韩在线一二三区| 欧美三区免费完整视频在线观看| 自拍偷在线精品自拍偷无码专区 | 狂野欧美性猛交blacked| 欧美乱妇15p| 日韩经典中文字幕一区| 欧美日韩成人综合| 日日嗨av一区二区三区四区| 欧美日韩一区二区三区免费看| 亚洲乱码中文字幕| 91国偷自产一区二区开放时间| 亚洲人成网站在线| 欧美日韩一级二级| 亚洲aaa精品| 欧美一区二区三区四区五区|