Wooden Sticks

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 10423    Accepted Submission(s): 4287

Problem Description
There is a pile of n wooden sticks. The length and weight of each stick are known in advance. The sticks are to be processed by a woodworking machine in one by one fashion. It needs some time, called setup time, for the machine to prepare processing a stick. The setup times are associated with cleaning operations and changing tools and shapes in the machine. The setup times of the woodworking machine are given as follows:

(a) The setup time for the first wooden stick is 1 minute. 
(b) Right after processing a stick of length l and weight w , the machine will need no setup time for a stick of length l' and weight w' if l<=l' and w<=w'. Otherwise, it will need 1 minute for setup.

You are to find the minimum setup time to process a given pile of n wooden sticks. For example, if you have five sticks whose pairs of length and weight are (4,9), (5,2), (2,1), (3,5), and (1,4), then the minimum setup time should be 2 minutes since there is a sequence of pairs (1,4), (3,5), (4,9), (2,1), (5,2).

 
Input
The input consists of T test cases. The number of test cases (T) is given in the first line of the input file. Each test case consists of two lines: The first line has an integer n , 1<=n<=5000, that represents the number of wooden sticks in the test case, and the second line contains n 2 positive integers l1, w1, l2, w2, ..., ln, wn, each of magnitude at most 10000 , where li and wi are the length and weight of the i th wooden stick, respectively. The 2n integers are delimited by one or more spaces.
 
Output
The output should contain the minimum setup time in minutes, one per line.
 
Sample Input
5
4 9 5 2 2 1 3 5 1 4
3
2
2 1 1 2
2
3
1 3 2 2 3 1
 
Sample Output
2
1
3
 
Source
 
Recommend
We have carefully selected several similar problems for you:  1050 1052 1045 1053 1789 

 
  水题。
  先对木材长度 l 排序,在对 w 依次处理,将第一个递增序列筛选出来,筛选出来的元素赋值为-1,再将第二个递增序列筛选出来,同样标记-1 ,直到w序列全部为-1,代表筛选完成。输出记录下的递增序列的个数就是结果。
  还可以用贪心做,有时间再做一遍。
  代码:
 #include <iostream>

 using namespace std;
struct stick{
int l,w;
}s[];
int main()
{
int T;
cin>>T;
while(T--){
int n;
cin>>n;
for(int i=;i<=n;i++)
cin>>s[i].l>>s[i].w;
//对l排序
for(int i=;i<=n-;i++)
for(int j=;j<=n-i;j++){
if(s[j].l>s[j+].l){
int t;
t=s[j].l;s[j].l=s[j+].l;s[j+].l=t;
t=s[j].w;s[j].w=s[j+].w;s[j+].w=t;
}
}
int sum=; //递增序列的个数
//对w序列进行筛选
while(){
int i;
for(i=;i<=n;i++){ //如果全部为-1,则退出循环
if(s[i].w!=-)
break;
}
if(i>n) break;
sum++;
int num=;
for(i=;i<=n;i++){
if(num== && s[i].w!=-){
num=s[i].w;
s[i].w=-;
}
else if(s[i].w!=- && s[i].w>=num){
num=s[i].w;
s[i].w=-;
}
}
}
cout<<sum<<endl; }
return ;
}

Freecode : www.cnblogs.com/yym2013

最新文章

  1. Android_安卓为按钮控件绑定事件的五种方式
  2. jquery之toggleClass应用
  3. 【引】objective-c,4:category的原理
  4. linux 环境变量PATH路径的三种方法
  5. jQuery点缩略图显示大图片
  6. dedecms 模板文件不存在,无法解析文档&quot;的终极各种解决办法
  7. 【CodeVS 1014】装箱问题
  8. R(一): R基础知识
  9. SVN提交数据失败问题(提示 svn:MKACTIVITY ... 403 Forbidden )
  10. Eclipse 安装反编译插件jadclipse(经验总结)
  11. js加载优化-二
  12. Linux 网络编程基础(3) -- 数据的IO
  13. 移动端 iphone touchmove滑到边界(浏览器地址拦及以上) touchend失效解决办法
  14. SQL索引--基础理论
  15. 看懂SqlServer查询计划 SQL语句优化分析
  16. git记录(给老婆找的地址)
  17. dubbo的InvocationChain
  18. Tag功能介绍—我们为什么打Tag?
  19. LAB8 android
  20. C++ Primer 笔记——类

热门文章

  1. COSMOSBOX手遊制作手册(Word备份)
  2. 解决ios7.0 以后自己定义导航栏左边button靠右的问题
  3. EAS开发
  4. vue 项目心得
  5. SVN 常见命令
  6. CSS总结:
  7. struts2 ValueStack的作用
  8. 基于RxJava2+Retrofit2简单易用的网络请求实现
  9. Mysql报错......\xE6\x80\xBB\xE7\x9B\x91&#39; for column...
  10. Bootstrap-学习系列