• <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>
            posts - 183,  comments - 10,  trackbacks - 0

            電梯調(diào)度算法

            http://m.shnenglu.com/jake1036/archive/2011/06/29/149720.html

            n1
            n2
            n3

            自下向上
            自上向下

            n1 + n2  n3
            n2 + n3  n1

             1 #include <iostream>
             2 using namespace std;
             3 
             4 int whichFloorDownToUp(int ps[], int n)
             5 {
             6     if (n <= 1)
             7     {
             8         return 0;
             9     }
            10     else if (n == 2)
            11     {
            12         return 1;
            13     }
            14     int all = 0;
            15     int n1 = ps[0];
            16     int n2 = ps[1];
            17     int n3 = 0;
            18     int retf = 1;
            19 
            20     for (int i = 2; i != n; ++i)
            21     {
            22         all += ps[i] * (i - 1);
            23         n3 += ps[i];
            24     }
            25 
            26     for (int i = 2; i != n; ++i)
            27     {
            28         if (n1 + n2 <= n3)
            29         {
            30             all += (n1 + n2 - n3);
            31             n1 += n2;
            32             n2 = ps[i];
            33             n3 -= ps[i];
            34             // cout << i << endl;
            35             retf = i;
            36         }
            37     }
            38     return retf;
            39 }
            40 
            41 int whichFloorUpToDown(int ps[], int n)
            42 {
            43     if (n <= 1)
            44     {
            45         return 0;
            46     }
            47     else if (n == 2)
            48     {
            49         return 1;
            50     }
            51     int all = 0;
            52     int n3 = 0;
            53     int n2 = ps[n - 1];
            54     int n1 = 0;
            55     int retf = n - 1;
            56     for (int i = n - 2; i >= 0--i)
            57     {
            58         all += ps[i] * (n - 1 - i);
            59         n1 += ps[i];
            60     }
            61 
            62     for (int i = n - 2; i >= 0--i)
            63     {
            64         if (n2 + n3 <= n1)
            65         {
            66             all += (n2 + n3 - n1);
            67             n3 += n2;
            68             n2 = ps[i];
            69             n1 -= ps[i];
            70             // cout << i << endl;
            71             retf = i;
            72         }
            73     }
            74     return retf;
            75 }
            76 
            77 int main()
            78 {
            79     int ps[] = {053289189258};
            80     cout << whichFloorDownToUp(ps, sizeof (ps) / sizeof (*ps)) << endl;
            81     cout << whichFloorUpToDown(ps, sizeof (ps) / sizeof (*ps)) << endl;
            82     return 0;
            83 }

             


            posted on 2011-08-03 18:01 unixfy 閱讀(341) 評(píng)論(0)  編輯 收藏 引用

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            久久精品国产91久久麻豆自制| 99久久精品国产免看国产一区| 精品国产婷婷久久久| 激情五月综合综合久久69| 久久综合九色综合欧美就去吻| 亚洲伊人久久精品影院| 日韩人妻无码一区二区三区久久| 久久ZYZ资源站无码中文动漫 | 亚洲AV乱码久久精品蜜桃| 久久偷看各类wc女厕嘘嘘| 99久久国产综合精品成人影院| 一本色道久久88综合日韩精品| 日产精品久久久一区二区| 狠狠久久综合伊人不卡| 蜜臀av性久久久久蜜臀aⅴ麻豆 | 久久久无码人妻精品无码| 国产福利电影一区二区三区久久久久成人精品综合 | 亚洲国产综合久久天堂| 精品久久久久久亚洲精品| 久久综合亚洲色HEZYO国产| 成人国内精品久久久久一区| 中文成人久久久久影院免费观看| 久久久久免费精品国产| 亚洲中文精品久久久久久不卡| 热久久国产欧美一区二区精品| 伊人久久综合热线大杳蕉下载| 奇米影视7777久久精品| 亚洲国产成人精品久久久国产成人一区二区三区综 | 亚洲欧美一区二区三区久久| 99久久精品国内| 久久99中文字幕久久| 97久久国产综合精品女不卡| 国内精品久久久久久久涩爱| 丁香狠狠色婷婷久久综合| 久久亚洲私人国产精品| 97久久婷婷五月综合色d啪蜜芽 | 久久综合一区二区无码| 国产一区二区精品久久凹凸 | 亚洲精品蜜桃久久久久久| 亚洲伊人久久综合中文成人网| 狠狠久久综合|