好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁(yè) > 知識(shí)庫(kù) > 算法系列15天速成 第十天 棧

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

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


一: 概念

         棧,同樣是一種特殊的線性表,是一種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 SeqStackT>
    {
        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 SeqStackT> SeqStackInitT>(int length)
        {
            SeqStackT> seqStack = new SeqStackT>(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 SeqStackPushT>(SeqStackT> 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 SeqStackPopT>(SeqStackT> seqStack)
        {
            if (SeqStackIsEmpty(seqStack))
                throw new Exception("嗚嗚,棧已空");

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

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

4:獲取棧頂元素

      這個(gè)很簡(jiǎn)單,跟“出棧”唯一不同的是不破壞棧頂元素,只是翻出來(lái)看看而已。

代碼段

復(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) + "個(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 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 棧是否已滿(mǎn)
        /// summary>
/// 棧是否已滿(mǎn)
/// /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 獲取棧中元素個(gè)數(shù)
        /// summary>
/// 獲取棧中元素個(gè)數(shù)
/// /summary>
/// typeparam name="T">/typeparam>
/// param name="seqStack">/param>
/// returns>/returns>
        public int SeqStackLenT>(SeqStackT> seqStack)
        {
            return seqStack.top + 1;
        }
        #endregion
    }
}



您可能感興趣的文章:
  • 算法系列15天速成 第十四天 圖【上】
  • 算法系列15天速成——第十三天 樹(shù)操作【下】
  • 算法系列15天速成 第十二天 樹(shù)操作【中】
  • 算法系列15天速成 第十一天 樹(shù)操作(上)
  • 算法系列15天速成 第八天 線性表【下】
  • 算法系列15天速成 第九天 隊(duì)列
  • 算法系列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)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《算法系列15天速成 第十天 棧》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于算法系列15天速成 第十天 棧的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 少妇性色午夜婬片AAA片软件| 美国一级毛片片aa久久综合| 97香蕉久久国产超碰青草专区| 美女内内裤摸自己下面的视频| 女女高潮抽搐喷潮18禁网站| 韩剧《甜性涩爱》在线观看| のエロ同人志无料エロ汉化| 亚洲一二三四区| 91九色丨PORNY首页黑人 | 午夜0时的吻免费完整版| 大尺度尤妮丝福利视频11| 五月婷婷开心网| 国产精品秘?入口福利| 亚洲欧美专区精品伊人久久| 老师办公室狂肉校花h| 给处女破处的过程| 精品国产91久久久久久老师| 欧州一级片| 女性向av| 久久96国产精品久久久| 初学生疯狂?喷一区免费视频| 国产人妻熟女ⅩXXX网站| japanesegril在线播放| 久久久久久精品免费| 国产男男Gay??体育生白袜 | 在线观看免费视频播放器| 好大好深好猛好爽视频| xvsr-488波多野结衣| 被室友cao翻了H双性| 女攻男总裁被cao到哭H漫画| 以色列禁止巴囚狂欢| 一级毛片无毒不卡直接观看| 91大神大战高跟丝袜美女| 现代黄色小说| 穿超短裙忘穿内裤公车| 操到喷水视频| 女配穿书病娇被强啪h| 纯肉高H啪动漫| 久久精品人人澡夜夜澡碰| 日韩在线播放全免费| 777yy午夜电影理论片|