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

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>
            国产精品日韩在线| 91久久综合| 一区二区av| av成人激情| 另类天堂视频在线观看| 欧美一级电影久久| 国产精品久久午夜| 一区二区三区鲁丝不卡| 99re成人精品视频| 欧美不卡视频一区发布| 欧美激情精品久久久六区热门 | 欧美不卡视频一区| 欧美第一黄色网| 亚洲高清资源| 美女亚洲精品| 亚洲国产精品精华液2区45| 亚洲国产欧美不卡在线观看 | 欧美激情成人在线| 亚洲电影免费观看高清完整版| 久久精品视频在线播放| 蜜桃久久av一区| 亚洲欧洲日韩综合二区| 欧美激情久久久久| 一区二区高清在线观看| 欧美一区二区三区男人的天堂| 国产精品亚洲不卡a| 欧美在线你懂的| 欧美大片免费| 一区二区三区福利| 国产免费亚洲高清| 久久久一本精品99久久精品66| 欧美黄色免费| 亚洲视频图片小说| 国产视频一区在线观看| 麻豆久久精品| 一区二区三区精品国产| 久久人人超碰| 亚洲精品一区二区三区樱花| 欧美色视频在线| 欧美一区二区三区在| 欧美国产在线电影| 亚洲自拍16p| 在线成人欧美| 欧美性大战久久久久久久蜜臀| 午夜视频一区在线观看| 国产欧美日韩综合精品二区| 午夜精品短视频| 欧美粗暴jizz性欧美20| 亚洲一区图片| 伊人男人综合视频网| 欧美精品18+| 亚洲午夜视频在线| 欧美va天堂va视频va在线| 中文一区在线| 永久久久久久| 国产精品日韩一区二区| 欧美成人嫩草网站| 亚洲欧美一区二区视频| 亚洲国产裸拍裸体视频在线观看乱了| 亚洲一区二区少妇| 亚洲国产成人av| 国产精品试看| 欧美日韩国产一区精品一区| 久久福利资源站| 亚洲视频每日更新| 亚洲激情一区| 鲁鲁狠狠狠7777一区二区| 亚洲欧美国产毛片在线| 亚洲人久久久| 在线观看一区二区视频| 国产精品一二三视频| 欧美精品免费在线观看| 久久九九久精品国产免费直播| 一本色道久久88综合亚洲精品ⅰ| 欧美jizz19hd性欧美| 久久久久**毛片大全| 亚洲综合电影| 9l视频自拍蝌蚪9l视频成人| 1000部精品久久久久久久久| 国产麻豆日韩欧美久久| 欧美日韩在线视频首页| 欧美国产亚洲另类动漫| 久久免费视频在线观看| 欧美一区二区黄| 亚洲欧美经典视频| 亚洲视频在线看| 一本大道久久a久久精品综合| 欧美成人一二三| 免费亚洲视频| 乱码第一页成人| 久久综合狠狠综合久久综合88 | 国产日韩欧美中文| 国产精品v亚洲精品v日韩精品| 欧美成人xxx| 免费亚洲电影| 免费成人av在线看| 男女激情久久| 欧美v国产在线一区二区三区| 久久久久久久久久久成人| 欧美在线视频观看| 久久国产夜色精品鲁鲁99| 小黄鸭精品aⅴ导航网站入口| 亚洲一区三区视频在线观看| 一个色综合导航| 亚洲午夜精品| 亚洲女人小视频在线观看| 亚洲一二三四久久| 亚洲一区中文字幕在线观看| 亚洲一区二区三区乱码aⅴ| 亚洲视频观看| 亚洲欧美日韩在线高清直播| 亚洲综合电影| 久久高清国产| 久久躁日日躁aaaaxxxx| 欧美成年人网站| 欧美日韩天天操| 国产精品福利av| 国产欧美日韩精品在线| 国产午夜一区二区三区| 黄色成人小视频| 亚洲国产精品欧美一二99| 亚洲美女网站| 中文精品视频| 久久精品日产第一区二区| 久久大综合网| 先锋资源久久| 久久精品观看| 蜜臀a∨国产成人精品| 欧美国产一区二区三区激情无套| 欧美日本一区| 国产日韩精品综合网站| 亚洲福利视频一区二区| 日韩亚洲欧美精品| 欧美一级夜夜爽| 欧美1区免费| 亚洲免费av电影| 性欧美大战久久久久久久久| 久久久中精品2020中文| 欧美人成在线| 国产一区在线视频| 亚洲精选在线| 久久精品免费电影| 亚洲三级国产| 久久se精品一区精品二区| 欧美高清影院| 国产日韩一区| 一区二区三区四区五区精品视频 | 亚洲影视九九影院在线观看| 久久精品一区二区| 亚洲国产日韩欧美在线99| 亚洲尤物在线视频观看| 久久久久久久综合日本| 欧美日韩国产色综合一二三四| 国语自产精品视频在线看抢先版结局 | 亚洲伦理中文字幕| 欧美中文字幕第一页| 亚洲丁香婷深爱综合| 亚洲欧美第一页| 欧美精品一区二区精品网| 国产午夜亚洲精品理论片色戒| 亚洲精品资源美女情侣酒店| 久久国产99| 日韩一区二区精品视频| 久久久久久尹人网香蕉| 国产欧美日韩在线播放| 亚洲视频一区在线观看| 欧美成人精品在线播放| 午夜欧美大尺度福利影院在线看| 欧美肥婆bbw| 在线精品一区| 久久女同精品一区二区| 亚洲影院在线观看| 欧美视频在线观看| 日韩视频二区| 亚洲高清一二三区| 久久人人爽人人| 国产一区二区三区在线观看免费视频| 亚洲免费观看在线观看| 欧美成人在线网站| 久久国产精品99国产精| 国产精品视频1区| 亚洲伊人久久综合| 99热精品在线| 欧美日韩国产大片| 夜夜爽夜夜爽精品视频| 欧美激情一区二区三级高清视频| 久久av资源网| 狠狠入ady亚洲精品| 久久精品亚洲精品| 午夜久久tv| 国产亚洲精品久久飘花| 欧美中文在线观看国产| 亚洲欧美一区二区精品久久久| 欧美小视频在线| 亚洲欧美日韩在线播放| 中文国产成人精品| 国产精品电影在线观看| 亚洲欧美中文在线视频| 亚洲最新在线| 国产精品欧美经典|