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

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 閱讀(4064) 評論(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>
            亚洲少妇最新在线视频| 亚洲影视在线播放| 久久久久国产精品一区二区| 国产色综合久久| 久久久精品性| 美女国内精品自产拍在线播放| 一区在线播放| 欧美国产一区二区在线观看 | 亚洲精品在线观看视频| 欧美国产一区二区| 99在线|亚洲一区二区| 一区二区日韩| 国产一级一区二区| 欧美性猛片xxxx免费看久爱| 香蕉久久夜色精品国产| 欧美一区二区三区精品电影| 最新日韩在线视频| 中文一区字幕| 在线观看日韩www视频免费| 亚洲国产岛国毛片在线| 欧美日韩国产区一| 久久精品国产免费看久久精品| 老司机一区二区| 亚洲视频综合| 久久精品国产99国产精品澳门| 欧美三级电影一区| 久久精品人人爽| 欧美成人精品高清在线播放| 午夜电影亚洲| 蜜臀av在线播放一区二区三区 | 国产欧美一区二区三区久久| 免费观看欧美在线视频的网站| 欧美精品一区二区视频| 欧美自拍偷拍| 欧美日韩免费视频| 麻豆精品一区二区av白丝在线| 欧美日韩精品不卡| 欧美 日韩 国产 一区| 国产精品乱子乱xxxx| 欧美激情第三页| 国产日韩亚洲欧美| 亚洲茄子视频| 亚洲国产精品一区二区www| 亚洲一区二区伦理| 夜夜嗨av一区二区三区| 久久爱www| 欧美一区二区三区在线| 欧美日韩国产首页在线观看| 欧美成人一区在线| 国产一区激情| 欧美一区高清| 久久国产欧美| 国产精品久久久久久超碰| 亚洲国产第一页| 亚洲国产精品欧美一二99| 欧美中文字幕第一页| 亚洲欧美日韩中文在线制服| 欧美日韩国产综合一区二区| 欧美国产日韩在线观看| 在线观看成人一级片| 久久精品首页| 另类欧美日韩国产在线| 国产一区二区成人| 小嫩嫩精品导航| 久久九九热re6这里有精品| 国产精品亚洲片夜色在线| 亚洲在线免费| 久久爱www| 国产一区二区久久| 午夜欧美不卡精品aaaaa| 亚洲欧美一区在线| 国产精品午夜在线| 性欧美大战久久久久久久久| 久久久久国产精品一区三寸| 狠狠色丁香久久综合频道| 久久福利一区| 亚洲国产成人av| 一本色道精品久久一区二区三区| 欧美欧美天天天天操| 亚洲精品欧美一区二区三区| 亚洲丝袜av一区| 国产精品永久免费视频| 久久av在线| 亚洲第一免费播放区| 一本色道久久99精品综合 | 亚洲欧美www| 久久久午夜精品| 在线精品视频免费观看| 欧美99在线视频观看| 亚洲精品乱码久久久久久| 亚洲天堂av在线免费观看| 国产欧美日韩三级| 久久久久天天天天| 亚洲精品偷拍| 久久精品国产欧美激情| 亚洲黄网站在线观看| 国产精品www色诱视频| 午夜视黄欧洲亚洲| 女同一区二区| 午夜精品免费视频| 亚洲第一精品夜夜躁人人躁| 国产精品播放| 老司机凹凸av亚洲导航| 一本色道久久综合亚洲精品不卡| 久久九九久久九九| 一区二区三区欧美在线观看| 国产亚洲欧美色| 欧美视频在线免费| 久久女同精品一区二区| 一区二区高清在线| 免费看成人av| 亚洲欧美视频一区| 91久久在线| 国内久久精品| 国产精品系列在线播放| 欧美精品久久天天躁| 久久爱另类一区二区小说| 9久re热视频在线精品| 蜜臀av一级做a爰片久久| 亚洲欧美日韩综合aⅴ视频| 亚洲精品午夜| 亚洲成色www8888| 国产亚洲欧美日韩精品| 欧美天天视频| 欧美国产精品劲爆| 久久综合影视| 久久成人免费视频| 亚洲一区二区精品在线观看| 日韩午夜三级在线| 亚洲视频一起| 亚洲乱码精品一二三四区日韩在线 | 亚洲欧美另类国产| 日韩视频一区二区三区在线播放| 免费在线一区二区| 久久久美女艺术照精彩视频福利播放| 亚洲午夜一区| 这里只有精品视频在线| 日韩视频在线免费观看| 亚洲高清123| 亚洲国产精品毛片| 亚洲成色www8888| 亚洲福利视频三区| 在线观看成人av电影| 国产综合视频| 精品福利av| 1769国产精品| 亚洲人成网站影音先锋播放| 亚洲国产精品久久久久婷婷老年| 亚洲国产精品va在看黑人| 激情综合网址| 亚洲国产高清自拍| 亚洲欧洲综合另类| 亚洲精品小视频在线观看| 99国产精品99久久久久久粉嫩| 99riav久久精品riav| 亚洲网站啪啪| 午夜性色一区二区三区免费视频| 欧美一区二区视频免费观看| 久久精品国产v日韩v亚洲| 久久综合五月| 亚洲国产成人久久综合一区| 99国产一区二区三精品乱码| 亚洲神马久久| 久久精品国产v日韩v亚洲| 免费欧美在线| 国产精品wwwwww| 黄色日韩在线| 亚洲伦理在线免费看| 亚洲欧美日本日韩| 久久婷婷国产综合尤物精品| 欧美韩日视频| 亚洲一区二区三区高清| 久久精品免费看| 欧美精品福利视频| 国产精品视频在线观看| 一区二区三区在线看| 在线一区二区三区四区五区| 欧美一级久久久久久久大片| 欧美黄在线观看| 亚洲手机在线| 亚洲开发第一视频在线播放| 亚洲影音一区| 麻豆九一精品爱看视频在线观看免费| 欧美激情成人在线视频| 国产日韩在线一区| 亚洲激情综合| 久久久久九九九| 亚洲精品之草原avav久久| 欧美一级免费视频| 欧美日韩成人精品| 韩国三级电影一区二区| 亚洲色在线视频| 欧美不卡三区| 欧美亚洲一区| 国产精品久久久久久亚洲调教| 亚洲电影av在线| 久久精品国产在热久久| av成人免费在线| 玖玖综合伊人| 好看不卡的中文字幕|