青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

poj 2886 Who Gets the Most Candies? 約瑟夫環(huán)和反素數(shù)

   直接模擬約瑟夫環(huán)是N^2,況且這題每次移動的距離和方向都是不確定的,只能模擬,如果加快查找和移動的話,
可以提高速度,果斷用線段樹維護(hù)當(dāng)前位置前面有多少個人。
   至于反素數(shù)指的是求一個小于等于N的數(shù)字,使得其因子個數(shù)在1-N中是最大的。這個利用一個必要條件暴力搜索即可。
其實就是利用下面這2個性質(zhì)搜索的。
   性質(zhì)一:一個反素數(shù)的質(zhì)因子必然是從2開始連續(xù)的質(zhì)數(shù)。
性質(zhì)二:p=2^t1*3^t2*5^t3*7^t4.....必然t1>=t2>=t3>=....。

   代碼如下:
#include <stdio.h>
#include <string.h>
#include <math.h>
#include <algorithm>
using namespace std;

int nPrime[16] = {2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53};
int nAns;
int nCN;
const int MAX_N = 500010;
//nPow不會超過20
void InitBest(int nCur, int nI, int nMax, int nN, int nNum)
{
    if (nCur > nN) return;
    if (nNum > nCN){nAns = nCur;nCN = nNum;}
    if (nNum == nCN){nAns = min(nAns, nCur);}
    for (int i = 1; i <= nMax; ++i)
    {
        nCur *= nPrime[nI];
        if (nCur > nN)return;//不加這句優(yōu)化會超時
        if (nI < 15)
        InitBest(nCur, nI + 1, i, nN, nNum * (i + 1));
    }
}

char szNames[MAX_N][10];
int nValue[MAX_N];
int nTree[MAX_N << 2];
void PushUp(int nRt)
{
    nTree[nRt] = nTree[nRt << 1] + nTree[nRt << 1 | 1];
}

void BuildTree(int nL, int nR, int nRt, int nV)
{
    if (nL == nR)
    {
        nTree[nRt] = nV;
        return;
    }
    int nMid = (nL + nR) >> 1;
    BuildTree(nL, nMid, nRt << 1, nV);
    BuildTree(nMid + 1, nR, nRt << 1 | 1, nV);
    PushUp(nRt);
}

void Add(int nL, int nR, int nRt, int nP, int nV)
{
    if (nL == nR)
    {
        nTree[nRt] += nV;
    }
    else
    {
        int nMid = (nL + nR) >> 1;
        if (nP <= nMid)Add(nL, nMid, nRt << 1, nP, nV);
        else Add(nMid + 1, nR, nRt << 1 | 1, nP, nV);
        PushUp(nRt);
    }
}

int Query(int nL, int nR, int nRt, int nSum)
{
    if (nL == nR)
    {
        return nL;
    }
    int nMid = (nL + nR) >> 1;
    int nLs = nRt << 1;
    int nRs = nLs | 1;
    if (nTree[nLs] >= nSum) return Query(nL, nMid, nLs, nSum);
    else return Query(nMid + 1, nR, nRs, nSum - nTree[nLs]);
}

int main()
{
    //InitBest(1, 0, 15);
    int nN, nK;
    
    while (scanf("%d%d", &nN, &nK) == 2)
    {
        nK--;
        nAns = 2;
        nCN = 0;
        InitBest(1, 0, 20, nN, 1);
        //printf("ans:%d cn:%d\n", nAns, nCN);
        for (int i = 0; i < nN; ++i)
        {
            scanf("%s%d", szNames[i], &nValue[i]);
        }
        
        BuildTree(0, nN - 1, 1, 1);
        int nTotal = nN;
        int nPos;
        for (int i = 0; i < nAns; ++i)
        {
            nPos = Query(0, nN - 1, 1, nK + 1);
            //printf("nK:%d %s %d\n", nK, szNames[nPos], nValue[nPos]);
            nTotal--;
            Add(0, nN - 1, 1, nPos, -1);
            if (!nTotal)break;
            if (nValue[nPos] >= 0)
            {
                nK = (nK - 1 + nValue[nPos] + nTotal) % nTotal;
            }
            else
            {
                nK = ((nK + nValue[nPos]) % nTotal + nTotal) % nTotal;
            }
        }
        printf("%s %d\n", szNames[nPos], nCN);
    }
    
    return 0;
}

posted on 2012-09-14 20:53 yx 閱讀(1334) 評論(0)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)結(jié)構(gòu)

<2012年9月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

導(dǎo)航

統(tǒng)計

公告

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

me

好友

同學(xué)

網(wǎng)友

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久大香伊蕉在人线观看热2| 一区二区冒白浆视频| 欧美天天在线| 免费观看成人| 久久免费视频在线| 欧美一二三区在线观看| 亚洲手机在线| 99热精品在线| 日韩视频精品在线观看| 亚洲国产精品久久久久秋霞影院| 亚洲综合日韩| 亚洲一级二级| 羞羞视频在线观看欧美| 香蕉久久夜色精品国产| 亚洲欧美日本国产有色| 欧美一级黄色网| 每日更新成人在线视频| 欧美精品免费在线观看| 国产精品捆绑调教| 国产精品日日摸夜夜摸av| 国产精品国产福利国产秒拍| 国产目拍亚洲精品99久久精品 | 亚洲啪啪91| 日韩一级大片| 亚洲字幕在线观看| 欧美韩日视频| 久久综合伊人77777蜜臀| 亚洲福利视频专区| 亚洲欧美日韩中文视频| 欧美精品videossex性护士| 欧美三级欧美一级| 国内伊人久久久久久网站视频| 一区二区三区偷拍| 美日韩精品免费| 亚洲欧美日本伦理| 欧美性猛交视频| 亚洲精品在线免费观看视频| 猛男gaygay欧美视频| 久久国产一区二区三区| 国产农村妇女毛片精品久久莱园子| 亚洲欧洲三级| 99这里只有精品| 欧美日韩成人激情| 欧美有码在线视频| 久久九九99视频| 在线精品一区| 91久久精品一区| 欧美日韩不卡合集视频| 亚洲视频一区| 午夜精品在线看| 国产视频久久久久久久| 久久免费高清| 久久久久久噜噜噜久久久精品| 国产视频在线观看一区二区三区| 亚洲永久精品国产| 久久成人国产| 亚洲毛片在线免费观看| 亚洲伦理在线免费看| 欧美激情影院| 另类人畜视频在线| 国产一二精品视频| 欧美在线不卡| 欧美高清在线视频| 亚洲男女自偷自拍图片另类| 性做久久久久久免费观看欧美| 狠狠色伊人亚洲综合网站色| 亚洲人成人一区二区在线观看| 激情久久久久久久| 亚洲一区高清| 在线视频亚洲一区| 欧美成人免费小视频| 乱人伦精品视频在线观看| 国产综合欧美| 久久国产加勒比精品无码| 新片速递亚洲合集欧美合集| 欧美二区在线播放| 亚洲精品一区二区三区樱花| 一区二区三区三区在线| 欧美另类变人与禽xxxxx| 亚洲电影成人| 亚洲天堂免费观看| 欧美日韩黄色大片| 亚洲综合第一| 久久久综合视频| 亚洲国产高清高潮精品美女| 欧美成人精品不卡视频在线观看 | 国产综合久久久久久| 久久久久99| 夜夜嗨av一区二区三区| 香蕉免费一区二区三区在线观看 | 国产精品福利在线观看网址| 亚洲欧美在线免费| 久久精品国产99精品国产亚洲性色 | 欧美日韩在线亚洲一区蜜芽| 欧美大片免费观看| 最近中文字幕mv在线一区二区三区四区 | 国产伦精品一区二区三区免费 | 亚洲国产日韩在线一区模特| 麻豆精品网站| 99re热这里只有精品视频| 午夜一区在线| 亚洲精品中文字| 国模吧视频一区| 欧美日本一区| 欧美国产专区| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲欧美国产制服动漫| 亚洲第一在线| 欧美激情91| 老司机午夜精品| 蜜臀久久久99精品久久久久久| 亚洲欧美日韩精品久久奇米色影视| 亚洲激情一区| 日韩视频在线免费| 亚洲人久久久| 夜夜夜久久久| 亚洲你懂的在线视频| 亚洲欧美欧美一区二区三区| 亚洲在线日韩| 亚洲欧美日韩精品综合在线观看| 亚洲黄色有码视频| 亚洲欧洲精品一区二区三区波多野1战4| 久久美女艺术照精彩视频福利播放| 欧美一区二区三区久久精品茉莉花| 中文国产成人精品久久一| 在线视频你懂得一区| 午夜精品久久久久久| 久久综合一区二区三区| 欧美韩国在线| 亚洲欧美国产日韩中文字幕| 久久亚洲精选| 国产精品毛片a∨一区二区三区|国 | 在线视频你懂得一区二区三区| 亚洲视频免费看| 久久精品视频在线观看| 亚洲黄色一区二区三区| 久久精品国产77777蜜臀| 欧美二区在线观看| 精品不卡在线| 久久不射电影网| 国产欧美精品在线播放| 一二三四社区欧美黄| 美脚丝袜一区二区三区在线观看 | 国产精品丝袜白浆摸在线| 亚洲黄色影院| 卡通动漫国产精品| 欧美一区二区三区视频在线 | 麻豆91精品91久久久的内涵| 国产精品中文字幕在线观看| 在线观看国产欧美| 久久久亚洲高清| 久久国产精品电影| 红桃视频一区| 欧美激情欧美激情在线五月| 看欧美日韩国产| 亚洲精品国产精品国自产在线| 欧美刺激午夜性久久久久久久| 久久久国产一区二区三区| 一色屋精品视频在线看| 免费成人在线观看视频| 久久阴道视频| 亚洲黄页一区| 亚洲自拍偷拍视频| 1024精品一区二区三区| 欧美大片免费观看在线观看网站推荐| 久久人人爽人人爽| 亚洲一区二区三区在线观看视频| 小黄鸭精品aⅴ导航网站入口| 狠狠色丁香婷婷综合影院| 亚洲国产精品va在线看黑人动漫 | 亚洲欧美成人一区二区三区| 欧美视频在线免费看| 久久久久综合一区二区三区| 欧美高清视频一区二区三区在线观看| 一区二区三区视频在线| 久久人人97超碰国产公开结果| 亚洲调教视频在线观看| 久久久欧美一区二区| 一区二区高清| 免费人成网站在线观看欧美高清 | 亚洲尤物视频在线| 久久亚洲午夜电影| 久久久久亚洲综合| 国产视频欧美视频| 亚洲精品一区二区三区婷婷月 | 亚洲国产精品激情在线观看| 国产精品成人在线观看| 久久影院亚洲| 欧美日本中文字幕| 久久久一区二区| 国产精品激情偷乱一区二区∴| 噜噜噜在线观看免费视频日韩| 欧美日韩免费区域视频在线观看| 美女精品一区| 国产一区二区三区在线观看免费| 亚洲第一成人在线| 亚洲国产精品高清久久久| 中日韩视频在线观看| 亚洲日本中文字幕| 老司机一区二区三区|