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

            最新評論

            閱讀排行榜

            老司机午夜网站国内精品久久久久久久久 | 精品久久久久久成人AV| 精品综合久久久久久888蜜芽| 色妞色综合久久夜夜| 狠狠精品干练久久久无码中文字幕| 久久久久久A亚洲欧洲AV冫| 亚洲中文字幕无码一久久区| 大蕉久久伊人中文字幕| 久久综合综合久久综合| 久久久久久国产a免费观看不卡| av色综合久久天堂av色综合在| 久久精品视频网| 亚洲午夜久久久久久久久电影网| 青青国产成人久久91网| 无码精品久久久久久人妻中字| 激情综合色综合久久综合| 久久人人妻人人爽人人爽| 久久亚洲国产成人精品无码区| 久久电影网一区| 久久国产精品99国产精| 久久人人爽人人爽人人片AV不 | 国产99久久久久久免费看| 色婷婷综合久久久久中文| 久久精品综合网| 狠狠色丁香久久婷婷综合_中| 久久精品国产精品亚洲艾草网美妙 | 色青青草原桃花久久综合| 久久亚洲欧洲国产综合| 91亚洲国产成人久久精品| 国产精品一区二区久久精品| 久久精品中文闷骚内射| 久久婷婷五月综合97色| 少妇内射兰兰久久| 亚洲精品美女久久777777| 欧美一区二区三区久久综| 日韩人妻无码精品久久免费一| 国产A三级久久精品| 欧美熟妇另类久久久久久不卡 | 狠狠色丁香久久婷婷综合蜜芽五月| 久久婷婷五月综合97色直播| 久久精品夜色噜噜亚洲A∨|