• <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.另外還要注意一些細(xì)節(jié),結(jié)構(gòu)體中將j、f設(shè)為int,cm為float,因此要將cm=1.0*f/j,否則cm的值會為0。
            posted on 2012-02-19 21:56 小鼠標(biāo) 閱讀(262) 評論(0)  編輯 收藏 引用

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


            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            常用鏈接

            隨筆分類(111)

            隨筆檔案(127)

            friends

            最新評論

            閱讀排行榜

            久久午夜无码鲁丝片午夜精品| 一本色道久久综合亚洲精品| 伊色综合久久之综合久久| 久久久综合香蕉尹人综合网| 久久精品国产只有精品2020| 久久久久国产精品| 久久久久一本毛久久久| 久久久久久青草大香综合精品| 亚洲国产精品综合久久网络 | 国产精品久久久久久一区二区三区| 久久99精品国产一区二区三区| 国产日韩久久久精品影院首页| 7777精品久久久大香线蕉| 色偷偷久久一区二区三区| 精品久久久久久国产免费了| 77777亚洲午夜久久多喷| 日本三级久久网| 国产精品一区二区久久精品无码 | 国内精品久久久久久久coent| 亚洲欧美一区二区三区久久| 久久综合九色综合精品| 久久天天躁狠狠躁夜夜2020一 | 亚洲欧洲日产国码无码久久99| 一本伊大人香蕉久久网手机| 精品久久人妻av中文字幕| 亚洲精品无码久久久影院相关影片| 97久久精品人人做人人爽| 久久久久久无码Av成人影院| 一本一本久久A久久综合精品| 久久精品无码一区二区三区日韩| 国产午夜久久影院| 久久99国产精一区二区三区| 午夜天堂精品久久久久| 99精品久久久久久久婷婷| 久久婷婷是五月综合色狠狠| 色婷婷狠狠久久综合五月| 欧美成人免费观看久久| 午夜福利91久久福利| 久久综合精品国产一区二区三区 | 日韩AV无码久久一区二区| 四虎国产精品成人免费久久|