青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Welcome to Leon's Blog  
日歷
<2009年6月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011
統(tǒng)計(jì)
  • 隨筆 - 30
  • 文章 - 0
  • 評(píng)論 - 51
  • 引用 - 0

導(dǎo)航

常用鏈接

留言簿(4)

隨筆分類

隨筆檔案

ACM

搜索

  •  

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

 
       今天早上終于提交成功了!這道題做了有一個(gè)星期多了,老是找不到原因。今天在偶然間發(fā)現(xiàn)了,先將代碼貼出來(lái),還請(qǐng)大家指正!感謝steven和一個(gè)匿名網(wǎng)友的建議,謝謝你們!但是程序運(yùn)行的時(shí)間還是過(guò)長(zhǎng),希望大家能夠幫助修改。

  1#include <stdio.h>
  2#include <string.h>
  3#include <stdlib.h>
  4
  5
  6int result[4];
  7int reNumber, reCount, tie, reMax;        //result是最終客戶的郵票種類,reCount是客戶郵票總個(gè)數(shù),reNumber是客戶不同郵票的個(gè)數(shù)
  8                                                    
  9int GetNumber(int *stamp, int *customer, int *stampNumber, int *customerNumber)        //獲取郵票 和 客戶信息。
 10{
 11    int i, n,count[100];    // count在這里起到一個(gè)優(yōu)化的作用。
 12    n = 0;
 13    (*stampNumber) = 0;
 14    memset(count, 0 ,sizeof(int)*100);
 15    while(1)        //收集關(guān)于郵票的面值。
 16    {
 17        if(scanf("%d"&n) == EOF)
 18            return -1;
 19        if(n == 0)
 20            break;
 21        if(count[n]++ < 5)
 22            stamp[(*stampNumber)++= n;
 23    }

 24    //stampNumber--;
 25    (*customerNumber) = 0;
 26    while(1)
 27    {
 28        scanf("%d"&n);        //收集關(guān)于客戶需要郵票的總面值數(shù)。
 29        if(n == 0)
 30            break;
 31        customer[(*customerNumber)++= n;
 32    }

 33    return 1;
 34}

 35int NotSame(int *number,const int count, int *m,int *stamp)        //求不同一組郵票類別的個(gè)數(shù)和郵票的最大面值。
 36{
 37    int i,j, c,s;
 38    c = 0;
 39    *= stamp[number[0]];
 40    for(i = 0; i < count; i++)
 41    {
 42        if*< stamp[number[i]])        //求最大面值的郵票
 43            *= stamp[number[i]];
 44        s = 0;
 45        for(j = 0; j < i; j++)        //求不同面值郵票的個(gè)數(shù)
 46        {
 47            if(number[i] == number [j])
 48            {
 49                s = 1;
 50                break;
 51            }

 52        }

 53        if(0 == s)
 54            c++;
 55    }

 56    return c;
 57}

 58
 59
 60void Divide(int sum, int *number, int *stamp,int n, int *count, int same,int start)
 61{
 62    int i;
 63    int t;
 64    if*count > 4 ) 
 65            return;
 66    else if( sum == 0 && *count <= 4)        //郵票個(gè)數(shù)《=4的時(shí)候且保存在數(shù)組number中的郵票面值=sum的時(shí)候。    
 67    {
 68        same = NotSame(number, *count,&t, stamp);
 69        if( same > reNumber || same == reNumber && reCount > *count || same == reNumber && reCount == *count && reMax < t )//根據(jù)不同的條件來(lái)判斷。
 70        {
 71            reMax = t;
 72            reCount = *count;
 73            reNumber = same;
 74            for(i = 0; i < *count; i++)
 75                result[i] = number[i];
 76            tie = 0;
 77        }

 78        else if(same == reNumber && reCount == *count && reMax == t)//當(dāng)郵票面值的最大值、郵票種類數(shù),郵票個(gè)數(shù)相等時(shí)。
 79        {
 80            tie = 1;
 81        }

 82
 83        return;
 84    }

 85    for(i = start; i < n; i++)        //遞歸搜索
 86    {
 87        sum -= stamp[i];
 88        if(sum >= 0)
 89        {
 90            number[(*count)++= i;
 91            Divide(sum, number, stamp, n, count,same,i);
 92            (*count)--;
 93        }

 94        sum += stamp[i];
 95    }
    
 96}

 97
 98
 99int main(int argc, char* argv[])
100{
101    int stamp[100], customer[100];        //stamp保存郵票的面值,customer保存客戶需要郵票的總面值。
102    int number[5];        //臨時(shí)數(shù)據(jù),記錄滿足條件的臨時(shí)結(jié)果。此前提交一直WA的原因是number分配的空間太小了!
103    int count,stampNumber = -1, customerNumber = -1;//stampNumber是郵票的個(gè)數(shù),customerNumber是客戶個(gè)數(shù) 
104    int i,j;
105
106    do
107    {    
108        memset(stamp, 0100*sizeof(int));
109        memset(customer, 0100*sizeof(int));
110        memset(number, 0 ,4);
111        if(GetNumber(stamp, customer, &stampNumber, &customerNumber) == -1)
112            break;
113        for(i = 0; i < customerNumber; i++)
114        {
115            reMax = -1;        //對(duì)數(shù)據(jù)初始化。
116            memset(result, 04);
117            reNumber = -1;
118            count=0;
119            tie = 0;
120            Divide(customer[i], number,stamp, stampNumber/*+1*/,&count, -1,0);
121            if(reNumber != -1)        //打印。
122            {
123                if(tie == 0)        //找到滿足條件的結(jié)果。
124                {
125                    printf("%d (%d):", customer[i], reNumber);
126                    for(j = 0; j <  reCount; j++)
127                            printf(" %d",stamp[result[j]]);
128                    printf("\n");
129                }

130                else if( tie == 1)    //存在郵票面值的最大值、郵票種類數(shù),郵票個(gè)數(shù)相同的答案
131                {
132                    printf("%d (%d): tie\n",customer[i], reNumber);
133                }

134            }

135            else        //不滿足條件
136            {
137                printf("%d ---- none\n",customer[i]);
138            }

139        }

140    }
while(1);
141    return 0;
142}

posted on 2008-07-01 09:56 Leon916 閱讀(1953) 評(píng)論(4)  編輯 收藏 引用
評(píng)論:

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


 
Copyright © Leon916 Powered by: 博客園 模板提供:滬江博客
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久久久国内| 亚洲国语精品自产拍在线观看| 欧美日韩国产成人在线免费 | 欧美性大战久久久久久久| 欧美在线1区| 99综合在线| 另类尿喷潮videofree| 午夜欧美理论片| 在线综合亚洲| 亚洲精品国产品国语在线app| 久久亚洲国产成人| 欧美一区二区三区在线视频| 亚洲午夜在线观看视频在线| 亚洲欧洲精品成人久久奇米网| 黄网站色欧美视频| 国产日韩亚洲欧美| 国产精品亚洲а∨天堂免在线| 欧美日韩精品系列| 国产精品美女诱惑| 欧美午夜www高清视频| 国产精品男人爽免费视频1| 国产麻豆视频精品| 国产精品蜜臀在线观看| 国产亚洲欧美日韩美女| 国产欧美日韩精品丝袜高跟鞋| 欧美日在线观看| 欧美日韩免费一区| 欧美欧美午夜aⅴ在线观看| 欧美成人按摩| 免费成人黄色av| 久久综合中文字幕| 欧美日韩一区二区欧美激情| 国产伦精品一区二区三区照片91 | 亚洲欧美日韩在线观看a三区 | 99热在这里有精品免费| 国产日韩一区欧美| 亚洲国产精品成人久久综合一区| 激情丁香综合| 日韩亚洲欧美成人| 欧美伊人久久久久久午夜久久久久 | 亚洲私人影院| 亚洲一区二区三区四区视频| 久久久精品免费视频| 亚洲国产欧美在线人成| 欧美亚洲日本网站| 欧美中文在线字幕| 欧美日一区二区在线观看| 国产在线视频欧美| 亚洲国产经典视频| 午夜精品视频在线观看| 欧美在线资源| 免费成人av| 欧美激情欧美狂野欧美精品| 亚洲黄色在线看| 亚洲最新在线| 久久婷婷国产综合精品青草| 欧美经典一区二区三区| 国产精品高潮呻吟| 韩国欧美一区| 亚洲三级毛片| 亚洲一区二区在线免费观看视频| 欧美在线视频二区| 亚洲另类在线一区| 亚洲欧美一区二区激情| 欧美日韩国产首页在线观看| 亚洲电影免费观看高清完整版在线| 亚洲美女视频| 午夜免费在线观看精品视频| 亚洲国产精选| 老司机精品视频网站| 国产日韩一区二区三区在线| 亚洲一区二区成人| 亚洲茄子视频| 欧美夫妇交换俱乐部在线观看| 欧美色精品天天在线观看视频 | 亚洲视频成人| 亚洲二区在线观看| 亚洲影视在线播放| 久久久水蜜桃| 欧美午夜精品电影| 一区二区三区久久精品| 久久精品视频在线播放| 亚洲国产日韩一级| 久久尤物电影视频在线观看| 国产在线观看一区| 久久福利一区| 亚洲欧美日韩综合国产aⅴ| 欧美性大战久久久久久久| 中国成人亚色综合网站| 亚洲日本一区二区三区| 欧美精品久久久久久久| 亚洲精品一级| 亚洲品质自拍| 欧美另类亚洲| 亚洲视频电影图片偷拍一区| 亚洲乱码国产乱码精品精 | 久久久最新网址| 激情久久婷婷| 美女尤物久久精品| 可以免费看不卡的av网站| 亚洲国产精品久久久久婷婷老年| 欧美电影在线| 午夜视频在线观看一区二区三区 | 一区二区三区高清不卡| 麻豆精品一区二区av白丝在线| 在线国产精品一区| 欧美大学生性色视频| 欧美成人午夜免费视在线看片 | 亚洲综合精品四区| 欧美日韩亚洲综合一区| 亚洲伊人久久综合| 亚洲影院色在线观看免费| 国产精品一区二区在线| 久久久久久高潮国产精品视| 久久精品成人| 国产三级欧美三级日产三级99| 久久精品一区| 免费成人在线观看视频| 一区二区久久久久久| 亚洲视频免费在线观看| 国产一区二区中文字幕免费看| 久久天天躁夜夜躁狠狠躁2022| 久久综合色影院| 午夜欧美不卡精品aaaaa| 国产精品xxxav免费视频| 午夜一区在线| 99国产欧美久久久精品| 国产精品一香蕉国产线看观看| 久久婷婷激情| 欧美激情亚洲国产| 欧美亚洲专区| 美女免费视频一区| 亚洲女同在线| 亚洲香蕉伊综合在人在线视看| 欧美日韩一区视频| 久久福利资源站| 免费在线观看日韩欧美| 亚洲韩国精品一区| 欧美成人在线免费视频| 欧美色网在线| 久久综合九色九九| 欧美日韩播放| 久久综合网络一区二区| 久久九九热re6这里有精品| 激情欧美一区二区| 亚洲精品小视频在线观看| 国产性做久久久久久| 亚洲国内精品| 国产主播一区二区三区| 亚洲精品美女在线观看播放| 国产一二三精品| 亚洲日本一区二区三区| 狠狠色综合一区二区| 99re亚洲国产精品| 国产精品美女一区二区在线观看| 模特精品在线| 欧美日本国产在线| 久久青草久久| 欧美成人精品一区二区三区| 亚洲欧美在线播放| 欧美暴力喷水在线| 久久香蕉精品| 国产精品美女久久久久久免费| 亚洲成色999久久网站| 欧美日韩国产美女| 男人插女人欧美| 国产欧美日韩综合一区在线观看 | 欧美激情麻豆| 国产一区 二区 三区一级| 一区二区三区日韩精品视频| 亚洲欧洲日本在线| 欧美一区二区精美| 亚洲免费婷婷| 欧美日韩午夜在线视频| 亚洲高清视频的网址| 精品动漫一区| 欧美影院在线播放| 羞羞视频在线观看欧美| 欧美日韩性视频在线| 亚洲激情视频在线播放| 亚洲动漫精品| 久久免费精品视频| 久久综合亚州| 激情五月综合色婷婷一区二区| 午夜亚洲伦理| 欧美亚洲综合在线| 国产精品久久影院| 在线亚洲精品| 亚洲制服av| 国产精品久久久久久久久借妻| 亚洲精品偷拍| 一区二区三区精品国产| 欧美精品在线观看播放| 亚洲日韩中文字幕在线播放| 亚洲精品乱码久久久久久久久| 模特精品在线| 亚洲激情在线观看视频免费| 最新国产成人在线观看| 欧美成人免费播放| 91久久午夜|