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

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 閱讀(4029) 評論(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>
            国模私拍视频一区| 国产精品入口麻豆原神| 在线观看亚洲精品视频| 欧美r片在线| 牛牛影视久久网| 一区二区高清| 亚洲一区国产| 一区在线免费观看| 亚洲国产小视频在线观看| 欧美激情中文字幕乱码免费| 亚洲午夜激情网站| 久久国产毛片| 亚洲精品久久7777| 中国av一区| 樱花yy私人影院亚洲| 亚洲国产日韩在线一区模特| 欧美先锋影音| 久久久久久久激情视频| 欧美成人综合网站| 久久不射电影网| 欧美精品1区2区3区| 欧美在线综合| 欧美精品久久久久久久久老牛影院 | 欧美福利视频在线| 欧美亚日韩国产aⅴ精品中极品| 久久精品国产96久久久香蕉| 欧美成人中文字幕| 久久精品免视看| 欧美人与禽猛交乱配| 久久一区二区精品| 国产精品福利在线| 亚洲高清免费| 国产一区二区黄| 中国成人在线视频| 亚洲人午夜精品| 久久精品日韩一区二区三区| 亚洲综合国产激情另类一区| 免费人成网站在线观看欧美高清| 性欧美xxxx视频在线观看| 欧美精品三级在线观看| 另类天堂av| 国产视频自拍一区| 亚洲午夜激情网页| 亚洲午夜激情免费视频| 欧美激情一区二区在线| 欧美成人免费小视频| 国产曰批免费观看久久久| 在线一区观看| 亚洲小说春色综合另类电影| 蜜臀久久久99精品久久久久久| 久久精品中文字幕一区二区三区| 国产精品国产三级国产aⅴ9色 | 亚洲欧美日韩一区二区| 欧美精品一区二区三区高清aⅴ| 久久免费黄色| 国产综合婷婷| 亚洲最新视频在线| 欧美黄网免费在线观看| 亚洲第一精品久久忘忧草社区| 国产一区二区精品在线观看| 亚洲嫩草精品久久| 久久国产精品网站| 国自产拍偷拍福利精品免费一| 午夜精品区一区二区三| 欧美一区视频在线| 国产亚洲观看| 久久久久久久999| 欧美暴力喷水在线| 亚洲精品久久久久久久久久久久久| 另类尿喷潮videofree| 欧美成人自拍| 亚洲毛片在线观看| 欧美日韩免费一区二区三区视频| 99国产精品久久久久久久久久| 中文欧美日韩| 国产精品羞羞答答xxdd| 香蕉成人久久| 欧美国产视频在线| 一区二区三区欧美在线观看| 国产精品成人播放| 欧美在线视频一区二区三区| 你懂的国产精品| 99视频精品全部免费在线| 国产精品福利片| 久久久久久久一区二区三区| 亚洲国产成人精品视频| 亚洲一区二区在线播放| 国产日韩精品一区二区三区在线 | 午夜精品国产更新| 欧美激情亚洲激情| 亚洲在线视频| 亚洲第一页在线| 欧美小视频在线| 久久久综合网站| 亚洲天堂av在线免费| 久久中文字幕一区| 亚洲亚洲精品在线观看 | 亚洲精品免费在线播放| 国产精品国产三级国产普通话三级 | 欧美第一黄色网| 亚洲欧美日韩一区二区在线| 亚洲第一黄色| 国产精品高潮呻吟| 美女黄色成人网| 性欧美video另类hd性玩具| 亚洲国产精品成人va在线观看| 性欧美8khd高清极品| 亚洲精品久久| 韩国欧美一区| 国产精品乱码一区二区三区| 免费人成精品欧美精品| 性欧美暴力猛交69hd| 亚洲三级影片| 欧美成人xxx| 久久久久国内| 午夜精品美女久久久久av福利| 最新中文字幕一区二区三区| 国产亚洲精品美女| 国产精品久久久久久久免费软件 | 欧美精品1区| 蜜桃av一区二区| 久久精品视频亚洲| 午夜精品久久久久久久99水蜜桃 | 国产伦精品一区二区三区免费| 鲁大师影院一区二区三区| 香港久久久电影| 亚洲尤物视频在线| 一区二区三区毛片| 99ri日韩精品视频| 亚洲精品免费电影| 亚洲精品美女免费| 最新国产成人在线观看| 亚洲国产成人久久综合| 欧美国产精品v| 蜜桃伊人久久| 欧美成人免费全部观看天天性色| 久久亚洲一区二区三区四区| 久久精品成人一区二区三区| 欧美在线观看一区| 久久国产精品久久久久久电车| 午夜激情亚洲| 久久国产精品99国产| 欧美在线一区二区| 久久网站热最新地址| 美女福利精品视频| 欧美成人在线网站| 亚洲国产精品日韩| 亚洲精品国偷自产在线99热| 亚洲精品一级| 中文久久精品| 欧美在线观看视频在线| 久久久久国产精品一区二区| 老司机免费视频一区二区三区| 老司机亚洲精品| 欧美日韩高清在线一区| 国产精品成av人在线视午夜片| 国产精品国产福利国产秒拍| 国产色产综合产在线视频| 激情懂色av一区av二区av| 亚洲欧洲在线播放| 亚洲婷婷综合久久一本伊一区| 亚洲欧美日韩国产精品| 久久久欧美一区二区| 欧美激情国产高清| 一本色道久久88综合亚洲精品ⅰ | 亚洲欧美制服另类日韩| 久久www免费人成看片高清| 美女国内精品自产拍在线播放| 欧美伦理视频网站| 国产麻豆9l精品三级站| 亚洲高清中文字幕| 亚洲男女自偷自拍| 久久综合五月天婷婷伊人| 亚洲精品少妇| 欧美有码在线观看视频| 模特精品在线| 国产欧美日韩精品在线| 亚洲六月丁香色婷婷综合久久| 午夜精品理论片| 亚洲激情综合| 午夜精品成人在线| 欧美日韩精选| 亚洲成在人线av| 午夜精品久久久久久久99樱桃| 欧美大秀在线观看| 欧美亚洲三级| 欧美日韩一本到| 91久久久久久久久久久久久| 午夜亚洲视频| 亚洲精品久久久久久下一站| 久久激情视频免费观看| 国产精品jizz在线观看美国| 亚洲电影有码| 久久免费的精品国产v∧| 中文国产一区| 欧美日韩激情小视频| 亚洲国产精品久久久久婷婷老年| 亚洲欧美日韩综合一区| 亚洲精品女人| 久久精品卡一|