• <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>

            糯米

            TI DaVinci, gstreamer, ffmpeg
            隨筆 - 167, 文章 - 0, 評論 - 47, 引用 - 0
            數據加載中……

            POJ 2454 Jersey Politics 隨機

            思路:

            首先按照 J牛 的數量排序,最小的前 K 個肯定是一個組了。反正這組都是輸的,多爛都行。
            剩下的 2K 個元素,和肯定是超過 2K*500 的。問題就是要劃分一下,讓每個組的和都大于 K*500。
            這里沒有說一定要平均分,也沒說要滿足什么其他特殊條件,而且數據又特別小。
            所以就可以隨機的分別挑選兩個元素交換,然后看是否滿足條件了。

            代碼居然 0MS AC了,隨機的威力很大啊,只是不可能題題都用罷了。。

            #include <stdio.h>
            #include 
            <stdlib.h>
            #include 
            <math.h>

            int K, in[256], *ptr[256];

            int cmp(const void *a, const void *b)
            {
                
            return *(*(int **)a) - *(*(int **)b);
            }


            __inline 
            void swap(int **a, int **b)
            {
                
            int *= *a;
                
            *= *b;
                
            *= t;
            }


            int main()
            {
                
            int i, sa, sb, a, b;

                freopen(
            "e:\\test\\in.txt""r", stdin);

                scanf(
            "%d"&K);
                
            for (i = 0; i < 3*K; i++{
                    scanf(
            "%d"&in[i]);
                    ptr[i] 
            = &in[i];
                }

                qsort(ptr, 
            3*K, sizeof(ptr[0]), cmp);

                sa 
            = 0;
                
            for (i = K; i < 2*K; i++)
                    sa 
            += *ptr[i];
                sb 
            = 0;
                
            for (i = 2*K; i < 3*K; i++)
                    sb 
            += *ptr[i];
                
            while (1{
                    a 
            = (rand() % K) + K;
                    b 
            = (rand() % K) + 2*K;
                    sa 
            = sa - *ptr[a] + *ptr[b];
                    sb 
            = sb - *ptr[b] + *ptr[a];
                    swap(
            &ptr[a], &ptr[b]);
                    
            if (sa > 500*&& sb > 500*K)
                        
            break;
                }


                
            for (i = 0; i < 3*K; i++)
                    printf(
            "%d\n", ptr[i] - in + 1);
                
                
            return 0;
            }

            posted on 2010-03-31 15:16 糯米 閱讀(529) 評論(0)  編輯 收藏 引用 所屬分類: POJ

            久久综合伊人77777| 欧美激情精品久久久久久久九九九| 精品无码人妻久久久久久| 久久精品成人免费国产片小草| 久久精品亚洲福利| 97久久国产露脸精品国产| 狠狠色综合网站久久久久久久高清| 久久精品天天中文字幕人妻| 日本久久久久久中文字幕| 色欲综合久久躁天天躁| 久久受www免费人成_看片中文| 国产成人精品久久| 丁香久久婷婷国产午夜视频| 久久久久久国产a免费观看黄色大片 | 看全色黄大色大片免费久久久| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 婷婷伊人久久大香线蕉AV| 久久成人国产精品一区二区| 久久久久亚洲AV无码观看 | 亚洲Av无码国产情品久久| 亚洲精品国产字幕久久不卡| 久久精品成人欧美大片| 99久久精品费精品国产一区二区| 亚洲国产精品无码久久青草 | 久久亚洲国产中v天仙www | 亚洲欧美日韩精品久久| 国产aⅴ激情无码久久| 久久精品免费全国观看国产| 97久久综合精品久久久综合| 久久久久九九精品影院| 国产精品欧美亚洲韩国日本久久| 久久天堂AV综合合色蜜桃网| 久久精品亚洲AV久久久无码| 久久婷婷五月综合97色直播| 99久久国产综合精品成人影院| 久久99精品久久久久久动态图| 午夜精品久久久久9999高清| 国产精品无码久久四虎| 国产成人精品久久一区二区三区av| 99久久综合狠狠综合久久止| 久久精品亚洲日本波多野结衣|