• <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>
            老鼠與貓咪做交易,貪心算法,不斷選取單價最便宜的購買即可
            #include<stdio.h>
            #include
            <stdlib.h>
            #define MAX 10000
            typedef 
            struct 
            {
                
            float cm;
                
            int j;
                
            int f;
            }
            JF;
            int cmp( const void *a, const void *b)
            {
                JF 
            *= (JF *)a;
                JF 
            *= (JF *)b;
                
            if(p -> cm > q -> cm)
                    
            return 1;
                
            else 
                    
            return -1;
            }

            int main()
            {
                JF jf[
            1001];
                
            float left, get;
                
            int N;
                
            int i, j;
                scanf(
            "%f%d"& left, & N); 
                
            while(N != -1)
                
            {
                    
            for(i = 0; i < N; i++)//input && sort
                    {
                        scanf(
            "%d%d"&jf[i].j, &jf[i].f);
                        
            if(jf[i].j != 0//j為商品,f為單價。j==0時單價高到無窮 
                            jf[i].cm = 1.0 * jf[i].f / jf[i].j;
                        
            else
                            jf[i].cm 
            = MAX;
                    }

                    qsort(jf, N, 
            sizeof(JF), cmp);
                    
            get = 0;//init
                    for(i = 0; i < N && left > 0.0; i++)//trade
                    {
                        
            if(left >= jf[i].f)
                        
            {
                            left 
            -= jf[i].f;
                            
            get += jf[i].j;
                        }

                        
            else
                        
            {
                            
            get += jf[i].j * left / jf[i].f;
                            left 
            = 0.0;
                        }

                    }

                    printf(
            "%.3f\n"get);//out 
                    scanf("%f%d"& left, & N); 
                }

            }

             

            1.需要注意的是邊界情況,j的輸入是可以為0的,這個時候可以將單價cm=f/j設(shè)為無窮大。
            2.另外還要注意一些細節(jié),結(jié)構(gòu)體中將j、f設(shè)為int,cm為float,因此要將cm=1.0*f/j,否則cm的值會為0。
            posted on 2012-02-19 21:56 小鼠標 閱讀(268) 評論(0)  編輯 收藏 引用

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


            <2012年2月>
            2930311234
            567891011
            12131415161718
            19202122232425
            26272829123
            45678910

            常用鏈接

            隨筆分類(111)

            隨筆檔案(127)

            friends

            最新評論

            閱讀排行榜

            7777精品伊人久久久大香线蕉| 国产亚洲精品久久久久秋霞| 国产精品久久亚洲不卡动漫| 精品久久久久久综合日本| 99久久99久久| 久久人人爽人人爽AV片| 日本国产精品久久| 久久久久人妻一区二区三区| 99久久99这里只有免费的精品| 久久精品国产只有精品66| 色欲综合久久躁天天躁蜜桃| 久久99久久成人免费播放| 日韩精品久久久久久久电影蜜臀| 久久九九亚洲精品| 无码伊人66久久大杳蕉网站谷歌 | 国产精品99久久久精品无码| 国产精品美女久久久久久2018| 久久久久亚洲AV无码专区网站 | 狠色狠色狠狠色综合久久| 欧美激情精品久久久久久久九九九| 午夜精品久久久久久毛片| 伊人热热久久原色播放www| 青青青国产成人久久111网站| 国产成人精品三上悠亚久久| 亚洲国产高清精品线久久| 国产综合免费精品久久久| 久久久中文字幕| 99久久www免费人成精品| 国产精品久久久久9999| 国内精品伊人久久久久AV影院| 久久精品国产2020| 国内高清久久久久久| 中文字幕乱码久久午夜| 久久精品国产亚洲AV不卡| 久久久久国产精品人妻| 精品久久久久久中文字幕大豆网 | 久久99精品国产自在现线小黄鸭| 久久人人爽人人爽人人片AV麻烦| 亚洲国产天堂久久久久久| 亚洲国产日韩综合久久精品| 欧美激情一区二区久久久|