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

            最新評論

            閱讀排行榜

            久久久久97国产精华液好用吗| 国产成人AV综合久久| 亚洲国产综合久久天堂| 久久婷婷色综合一区二区| 亚洲欧美成人久久综合中文网| 无码人妻久久一区二区三区免费 | 久久久久九九精品影院| 久久无码AV一区二区三区| 国产精品久久久久久久久免费| 久久99精品国产麻豆婷婷| 亚洲AV成人无码久久精品老人| 国产香蕉97碰碰久久人人| 亚洲国产精品无码久久| 麻豆久久| 精品久久久久久无码人妻蜜桃| 久久天天躁狠狠躁夜夜96流白浆 | 国产精品99久久久精品无码| 久久香蕉综合色一综合色88| 中文字幕无码免费久久| 久久精品国产99久久久香蕉| 国产精品久久久久久搜索| 国产偷久久久精品专区| 中文成人无码精品久久久不卡| 人人狠狠综合久久亚洲婷婷| 色婷婷综合久久久中文字幕| 四虎亚洲国产成人久久精品| 亚洲欧美国产精品专区久久| 99久久精品国产一区二区蜜芽 | 久久精品无码一区二区无码| 午夜精品久久久久成人| 久久99精品九九九久久婷婷| 国产精品九九九久久九九| 99久久国产精品免费一区二区| 久久久久久久免费视频| 一本久道久久综合狠狠躁AV| 久久亚洲国产精品五月天婷| 久久婷婷色综合一区二区| 亚洲国产成人久久精品99 | 国产69精品久久久久99| 亚洲综合婷婷久久| 一本大道加勒比久久综合|