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

oyjpArt ACM/ICPC算法程序設計空間

// I am new in programming, welcome to my blog
I am oyjpart(alpc12, 四城)
posts - 224, comments - 694, trackbacks - 0, articles - 6

PKU 1011 Sticks

Posted on 2006-11-30 00:34 oyjpart 閱讀(4049) 評論(15)  編輯 收藏 引用 所屬分類: ACM/ICPC或其他比賽
這道題作的我真的是悲喜交加阿。。。做完之后。。。長舒一口氣。。推薦大家去做!??!

Sticks
Time Limit:1000MS? Memory Limit:10000K
Total Submit:18973 Accepted:4421

Description
George took sticks of the same length and cut them randomly until all parts became at most 50 units long. Now he wants to return sticks to the original state, but he forgot how many sticks he had originally and how long they were originally. Please help him and design a program which computes the smallest possible original length of those sticks. All lengths expressed in units are integers greater than zero.

Input
The input contains blocks of 2 lines. The first line contains the number of sticks parts after cutting, there are at most 64 sticks. The second line contains the lengths of those parts separated by the space. The last line of the file contains zero.

Output
The output should contains the smallest possible length of original sticks, one per line.

Sample Input

9
5 2 1 5 2 1 5 2 1
4
1 2 3 4
0

Sample Output

6
5 















1。我從大到小搜索了哇 沒用。。。
2。我想 用預先得到所有可拼湊長度來HASH 發現太大...
3。然后我想對每個長棍分開搜索...
4。后來我又用記錄數目的方法搜 似乎更慢...
終于發現真正重要的剪枝!
1.當一個正好可以填滿的時候 就不用考慮比他小的去填了
2.一大段的第一個小段如果不成立直接返回到上一大段
這才是重要的剪枝
同時還有一個 要預防反復搜索同一關鍵碼 給出下面的測試數據
64
40 40 40 40 40 40 40 40 40 40 40 40 40
40 40 40 40 40 40 40 40 40 40 43 42 42
41 10 4 40 40 40 40 40 40 40 40 40 40
40 40 40 40 40 40 40 40 40 40 40 40 40
40 40 40 40 40 40 40 40 40 40 40 40
0
呵呵 其實AC的程序里面有一大部分都過不了這個數據!包括0MSAC的!

呵呵 過了之后 心情好啊~`哈哈
//Solution
//by optimistic
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int nss;
int ss[70];
int used[70];
int totss;
int maxss;
int len;
int cmp(const void * a, const void * b)
{
?return (*(int *)b) - (*(int *)a);
}
int search(int times, int rest, int pos)
{
?int flag = 0;
?if(rest == len) flag = 1; //第一種剪枝
?int i;
?if(times == totss/len) return 1;
?for(i = pos; i<nss; i++)
??if(!used[i])
??{
???if(rest == ss[i])
???{
????used[i] = 1;
????if(search(times+1, len, 0))?return 1;
????used[i] = 0;
??? ?return 0;????????????????????? //第二種剪枝???????????????????????????????????????????????????????????????????
???}
???else if(ss[i]<rest)
???{
????used[i] = 1;
????if(search(times, rest-ss[i], i+1)) return 1;
????used[i] = 0;
????if(flag) return 0;
????while(ss[i] == ss[i+1]) i++;
???}
???else if(flag) return 0;
??}
?return 0;
}
int main()
{
//?freopen("t.in", "r", stdin);
?int i;
?while(scanf("%d", &nss), nss>0)
?{
??memset(ss, 0, sizeof(ss));
??totss = maxss = 0;
??for(i=0; i<nss; i++)
??{
???scanf("%d", &ss[i]);
???totss += ss[i];
???if(ss[i]>maxss) maxss = ss[i];
??}
??qsort(ss, 70, sizeof(ss[0]), cmp);
??for(i=maxss; i<=totss; i++)
??{
???if(i==totss)
???{printf("%d\n", totss); break;}
???if(totss%i==0)
???{?????
????memset(used, 0, sizeof(used));
????len = i;

????if(search(1, len, 0)) {printf("%d\n", i); break;}
???}
??}
?}
?return 0;
}




Feedback

# re: PKU 1011 Sticks   回復  更多評論   

2007-04-13 23:40 by Jun Wang
if(search(1, len, 0)) {printf("%d\n", i); break;}
是不是要改成 if(search(0, len, 0)) {printf("%d\n", i); break;} ??

# re: PKU 1011 Sticks   回復  更多評論   

2007-07-22 19:28 by Typhoooooooooooooooooooooooooooooooooon
感謝你那兩個重要的剪枝哈

# re: PKU 1011 Sticks   回復  更多評論   

2007-10-24 11:00 by delguoqing
你上面這個測試數據的ouput是多少?

# re: PKU 1011 Sticks   回復  更多評論   

2008-05-04 23:46 by mango
你測這個... 你的半天也出不來...
64
40 40 30 35 35 26 15 40 40 40 40 40 40 40 40 40 40 40 40 40 40

40 40 43 42 42 41 10 4 40 40 40 40 40 40 40 40 40 40 40 40 40

40 25 39 46 40 10 4 40 40 37 18 17 16 15 40 40 40 40 40 40 40

40

# re: PKU 1011 Sticks   回復  更多評論   

2008-05-05 09:02 by oyjpart
的確啊,很強大的數據啊

# re: PKU 1011 Sticks   回復  更多評論   

2008-05-05 18:42 by zoyi
答案是454~~可是我的程序居然是wa~5555555555

# re: PKU 1011 Sticks   回復  更多評論   

2008-05-05 20:10 by oyjpart
哦?你怎么知道答案啊

# re: PKU 1011 Sticks   回復  更多評論   

2008-05-06 19:43 by zoyi
我的程序跑出來的啊~~難道你懷疑我跑的是錯誤的???哈哈@oyjpart

# re: PKU 1011 Sticks   回復  更多評論   

2008-05-07 12:49 by mango
哎......這個數據真變態...煩死了 呵呵

# re: PKU 1011 Sticks   回復  更多評論   

2008-05-07 21:06 by oyjpart
哦。。。你過題了沒

# re: PKU 1011 Sticks   回復  更多評論   

2008-05-22 15:59 by zsong
我跑出454了,很快,不過也是wa

# re: PKU 1011 Sticks   回復  更多評論   

2008-08-12 20:45 by zjh777007
誰能告訴我
“一大段的第一個小段如果不成立直接返回到上一大段”
什么意思?

# re: PKU 1011 Sticks   回復  更多評論   

2008-08-12 20:53 by oyjpart
現在由一個當前情況S.
這個時候比如有一個大棍子,長度為20,現在嘗試在其中放入一個長度為5的小棍子。結果深搜得到的結果是不可行,則認為當前情況是無解的。
因為這個5長度的小棍子放不了這個大棍子,絕對放不了任何一根大棍子。

# re: PKU 1011 Sticks   回復  更多評論   

2008-11-30 11:29 by abc
#include<iostream>
#include<string>
#include<fstream>
#include<vector>
#include<ctime>
using namespace std;
fstream fin("e:\\office\\txt\\acmin.txt");
int l[65];
int s,t,min,sum=0,len;
int max2;
int count=0;
int c=0;
static int used[65];
int search(int leni, int s){
if(leni==0) return 100;
t=s;
int count=0;
while(l[t]>leni||used[t]){
t--;
if(t==0){
//break;
return 0;
}
}
used[t]=1;
count++;
if(l[t]<=leni){
int se=search(leni-l[t],s-1);

if(se>=100){
count+=(se-100);
//if((leni-l[t])!=0){
//if(count<s){
c=1;
for(int i=1;i<=s;i++)c*=used[i];
if(!c){
int sea=search(len,s-1);
if(sea>=100){
count+=(sea-100);
return count+100;
}/*else{
return 0;
}*/
//}
}
}
/*else{
return 0;
}*/
}
count+=100;
return count;
}
int main(){
cin>>s;
while(s){

max2=0;
sum=0;
count=0;
for(int i=0;i<65;i++)used[i]=0;
for(int i=1;i<=s;i++){
cin>>l[i];
if(l[i]>max2){
max2=l[i];
}
sum+=l[i];
}
for(int i=0;i<=s;i++){
for(int j=0;j<s-i;j++){
if(l[j]>l[j+1]){
int temp=l[j];
l[j]=l[j+1];
l[j+1]=temp;
}
}
}
cout<<"sum"<<sum<<endl;
for(int i=max2;i<=sum;i++){
len=i;

for(int j=0;j<65;j++)used[j]=0;
if(sum%i!=0)continue;

int k=search(i,s);

if(k>100){

if((k-100)==s){cout<<i<<endl;break;}
}else{
continue;
}
}
cin>>s;
}

}













# re: PKU 1011 Sticks   回復  更多評論   

2008-11-30 11:30 by abc
各位高手幫忙看一下上面的程序有什么錯誤,萬分感激!
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲一区在线免费| 亚洲人成免费| 欧美精品一区二区三区蜜臀| 亚洲伊人久久综合| 久久久国产精品一区| 国语自产精品视频在线看抢先版结局| 欧美成人中文字幕| 久久国产欧美精品| 久久久www免费人成黑人精品 | 国产精品视频九色porn| 国产精品福利在线| 国内精品久久久久久久97牛牛| 国产精品主播| 国产在线精品自拍| 欧美一区免费视频| 亚洲日本视频| 亚洲欧洲综合另类| 亚洲淫片在线视频| 老司机精品视频网站| 欧美日韩亚洲一区在线观看| 韩国av一区二区三区| 日韩一级片网址| 久久精品一区| 亚洲老板91色精品久久| 欧美一区二区三区在| 欧美理论电影在线播放| 国内精品久久久久伊人av| 日韩视频在线观看国产| 久久精品视频导航| 亚洲精品国久久99热| 麻豆九一精品爱看视频在线观看免费 | 一本色道久久99精品综合| 午夜精品一区二区三区在线播放| 久久国产精品久久久久久电车| 欧美成人在线网站| 国产一区二区剧情av在线| 99精品欧美一区二区三区| 99re热精品| 精品动漫av| 亚洲午夜久久久久久久久电影院| 亚洲一区二区三区午夜| 免费91麻豆精品国产自产在线观看| 国产精品国产三级国产普通话三级| 亚洲国产精品一区二区第四页av| 久久成人精品一区二区三区| 一本久久a久久精品亚洲| 欧美成人亚洲成人| 在线观看国产一区二区| 性久久久久久久久久久久| 日韩视频不卡中文| 欧美精品99| 亚洲人成人一区二区在线观看| 99re热精品| 亚洲午夜高清视频| 国产精品成人aaaaa网站 | 欧美体内she精视频| 亚洲激情视频网站| 欧美freesex交免费视频| 欧美一区永久视频免费观看| 国产精品丝袜白浆摸在线| 亚洲一区二区三区影院| 亚洲精品国产精品国自产观看| 亚洲一区二区三区四区中文| 欧美性一区二区| 亚洲综合精品自拍| 亚洲午夜影视影院在线观看| 国产精品久久亚洲7777| 亚洲永久精品大片| 一区二区三区高清不卡| 欧美视频在线观看一区| 性久久久久久久久| 久久精品一区二区三区不卡牛牛 | 亚洲国产99| 欧美大片专区| 一区二区欧美国产| 亚洲一区www| 国产日韩欧美91| 久久婷婷av| 欧美高清在线播放| 亚洲欧美日韩天堂| 性欧美xxxx视频在线观看| 国产香蕉97碰碰久久人人| 久久婷婷丁香| 欧美国产激情| 亚洲欧美精品中文字幕在线| 欧美专区日韩专区| 亚洲美女av网站| 午夜亚洲影视| 亚洲日本一区二区| 亚洲一区免费视频| 亚洲国产精品悠悠久久琪琪| 一本色道久久综合狠狠躁篇怎么玩 | 亚洲视频免费在线| 国产亚洲欧美一级| 亚洲国产欧美一区| 国产精品一区二区女厕厕| 免费在线观看成人av| 欧美特黄一级| 欧美成人免费大片| 国产精品欧美精品| 亚洲国产高清高潮精品美女| 国产精品夜色7777狼人| 亚洲欧洲综合另类| 亚洲高清激情| 欧美影院精品一区| 午夜激情一区| 欧美一区二区女人| 狠狠久久综合婷婷不卡| 欧美精品久久99| 欧美精品在线视频观看| 老司机成人在线视频| 久久综合久久88| 亚洲在线一区二区| 欧美一区二区三区久久精品茉莉花 | 亚洲免费伊人电影在线观看av| 亚洲国产精品成人| 91久久在线视频| 亚洲一区二区在线免费观看| 午夜伦理片一区| 午夜天堂精品久久久久| 欧美在线观看一区| 欧美制服丝袜第一页| 欧美高清在线精品一区| 欧美日本高清一区| 国产精品高潮呻吟| 黄色精品一区二区| 亚洲精品韩国| 久久er99精品| 91久久综合| 小辣椒精品导航| 另类激情亚洲| 一区二区视频免费完整版观看| 夜夜嗨一区二区| 免费在线看成人av| 欧美成年人在线观看| 一二三四社区欧美黄| 99在线热播精品免费| 欧美日韩一级黄| 久久精品伊人| 91久久精品一区二区别| 亚洲在线观看| 美女主播精品视频一二三四| 亚洲色无码播放| 欧美日韩ab片| 亚洲欧美日韩国产| 亚洲第一精品电影| 亚洲欧美制服另类日韩| 亚洲精品欧美在线| 欧美在线视频观看| 亚洲国产欧美日韩另类综合| 久久综合伊人77777麻豆| 欧美一级一区| 1204国产成人精品视频| 亚洲精品一品区二品区三品区| 欧美福利在线观看| 亚洲国产老妈| 中国亚洲黄色| 亚洲高清中文字幕| 亚洲欧美精品一区| 亚洲国内在线| 亚洲在线视频网站| 亚洲国产一区二区三区青草影视| 亚洲国产精品黑人久久久| 老司机精品视频网站| 亚洲欧美一区二区三区久久 | 久久久一二三| 亚洲夫妻自拍| 一区二区免费在线观看| 麻豆成人精品| 极品少妇一区二区三区| 亚洲欧美另类综合偷拍| 亚洲免费视频观看| 欧美色道久久88综合亚洲精品| 亚洲国产成人av好男人在线观看| 好男人免费精品视频| 欧美中文在线免费| 免费黄网站欧美| 亚洲激情在线观看| 欧美日韩国产不卡| 这里只有精品丝袜| 欧美亚洲日本国产| 午夜视频一区在线观看| 欧美日本中文字幕| 国产综合亚洲精品一区二| 亚洲欧美日韩在线观看a三区| 久久免费视频这里只有精品| 亚洲人www| 欧美激情a∨在线视频播放| 日韩视频免费在线| 欧美 日韩 国产一区二区在线视频| 欧美国产欧美亚洲国产日韩mv天天看完整 | 小黄鸭精品aⅴ导航网站入口| 欧美成人精品在线视频| 西瓜成人精品人成网站| 国产亚洲欧美一级| 久久综合伊人| 欧美三级视频在线播放| 日韩视频免费观看高清在线视频| 男女精品视频| 亚洲欧美精品在线观看|