• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            liyuxia713

            蹣跚前行者

            常用鏈接

            統(tǒng)計(jì)

            Algorithms

            C++

            最新評(píng)論

            [導(dǎo)入]用循環(huán)隊(duì)列輸出楊輝三角形

            用循環(huán)隊(duì)列輸出楊輝三角形貌似有點(diǎn)小題大做,但主要是為了練習(xí)隊(duì)列應(yīng)用嘛。說(shuō)實(shí)在這個(gè)小程序也讓我調(diào)試了很長(zhǎng)時(shí)間.

            用這個(gè)程序用戶就可以自行輸入想要的楊輝三角形的行數(shù)了。

            //YHTriangle.cpp
            //輸出楊輝三角形
            //算法思想:首先在循環(huán)隊(duì)列中存放第三行的 1,2,1和第四行的1.
            //若循環(huán)隊(duì)列隊(duì)頭元素和隊(duì)頭第二個(gè)元素均為1,則從隊(duì)頭刪除一個(gè)1,在隊(duì)尾插入兩個(gè)1.
            //若不然,將隊(duì)對(duì)頭元素和隊(duì)頭第二個(gè)元素相加,將和值插入到隊(duì)尾,刪除對(duì)頭一個(gè)元素。
            //若想輸出楊輝三角形n行,將循環(huán)隊(duì)列長(zhǎng)度設(shè)置成 n+2。
            //輸出:前兩行直接輸出。定義了print函數(shù)控制后面每行輸出的元素個(gè)數(shù)
            #include "Queue.h"
            #include "CycQueue.h"
            #include <iostream>
            using namespace std;

            //輸出n個(gè)空格
            void print_space(int n);
            //n行楊輝三角形的輸出格式
            void print(int k, int n);

            int main()
            {
                int n;
                cout << "Please enter the YangHui Triangle row number n:";
                cin >> n;

                CycQueue<int> YHTri(n+2);

                YHTri.push(1);
                YHTri.push(2);
                YHTri.push(1);
                YHTri.push(1);
               //輸出前兩行
                print(1,n);
                print(1,n);
                print(1,n);
                while( !YHTri.full())
                {
                    int a,b;
                    //若隊(duì)頭元素和隊(duì)頭第二個(gè)元素均為1
                    if( (YHTri.top() == 1) && (YHTri.second() == 1))
                    {
                        a = YHTri.pop_top();
                        YHTri.push(1);
                        YHTri.push(1);
                        print(a,n);
                    }
                    //若不然
                    else
                    {       
                        a = YHTri.pop_top();
                        b = YHTri.top();
                        YHTri.push(a + b);
                        print(a,n);           
                    }
                }

                //輸出循環(huán)隊(duì)列中留存的元素
                while( !YHTri.empty())
                {
                    print(YHTri.pop_top(),n);
                }

                system("pause");
                return 0;
            }

            void print_space(int n) //輸出n個(gè)空格
            {
                while(n--) cout << " ";
            }

            int i = 1, j = 0;
            void print(int k, int n) //n行楊輝三角形的輸出格式
            {
                if( i==1 ) print_space(n);
                if(j++ != i) ;
                else
                {
                    cout << endl;
                    print_space(n-i);
                    ++i;
                    j = 1;
                }
                cout << k <<" ";
            }

            //循環(huán)隊(duì)列的模板類聲明

            #ifndef CYCQUEUE_H
            #define CYCQUEUE_H

            #include <iostream>
            using namespace std;

            template<class T>
            class CycQueue:public Queue<T>
            {
            public:
                CycQueue(int maxsz = 100):len(maxsz)
                {
                    elems = new T[maxsz];
                    front = rear = 0;
                };
                ~CycQueue(){delete[] elems;    };

                void clear() {rear = front = 0;};
                int size()const
                bool full()const
                bool empty()const
                bool push(const T& item);
                bool pop();
                T top()const;
                T pop_top();
                T second()const;
            protected:
            private:
                int front;
                int rear;
                int len;
                T* elems;
            };

            #include "CycQueue.cpp"
            #endif

            循環(huán)隊(duì)列主要注意不要忘記%len,不然就都是莫名錯(cuò)誤啦!
            文章來(lái)源:http://liyuxia-life.spaces.live.com/Blog/cns!DA1B364675ACF35!271.entry

            posted on 2009-04-10 10:12 幸運(yùn)草 閱讀(2731) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Algorithms

            国产精品嫩草影院久久| 久久伊人五月丁香狠狠色| 四虎亚洲国产成人久久精品| 久久精品人人做人人爽97| 久久久亚洲欧洲日产国码是AV| 久久久久久亚洲精品无码| 蜜桃麻豆www久久| 91精品无码久久久久久五月天| 国产精品久久久久天天影视| 久久精品无码专区免费青青| 亚洲国产精品无码久久| 香蕉久久夜色精品升级完成| 亚洲欧美日韩中文久久| 亚洲国产精品无码久久久蜜芽 | 精品久久久久久久无码| 久久人人爽人人爽人人AV东京热 | 青青青青久久精品国产h| 精品久久久久久国产| 青青草国产成人久久91网| 欧美日韩中文字幕久久伊人| 国产2021久久精品| 欧美日韩中文字幕久久久不卡| 久久精品国产男包| 99久久精品日本一区二区免费| 亚洲成色999久久网站| 久久人人爽人人精品视频| 97精品伊人久久大香线蕉| 97久久精品无码一区二区| 久久久久久国产精品无码下载| 久久香综合精品久久伊人| 久久国产精品99精品国产| 久久久久99精品成人片牛牛影视| 亚洲天堂久久久| 久久96国产精品久久久| 日韩久久无码免费毛片软件 | 久久婷婷久久一区二区三区| 激情综合色综合久久综合| 漂亮人妻被中出中文字幕久久 | 婷婷久久综合九色综合98| 亚洲精品乱码久久久久久蜜桃 | 91精品国产综合久久香蕉 |