2679.跨时代

     1.题目描述

钟逆时针而绕,恶物狰狞的倾巢,我谦卑安静地于城堡下的晚祷,压抑远古流窜的蛮荒暗号,而管风琴键高傲的说,那只是在徒劳。我的乐器在环绕,时代无法淘汰我霸气的皇朝。 你无法预言,因为我越险,翅越艳;没有句点,跨时代蔓延,翼朝天。 月下浮雕,魔鬼的浅笑,狼迎风嚎,蝠翔似黑潮,用孤独去调尊严的色调。我跨越过世代,如兽般的姿态,琴声唤起沉睡的血脉。不需要被崇拜,如兽般的悲哀,只为永恒的乐曲存在,醒过来。 去年万众瞩目的《跨时代》专辑发行之后,周杰伦又开始了他的世界巡回演唱会《超时代》。有人说过:如果你喜欢一个人,那你一定要去看一场他的演唱会;电视机前的1m距离和在演唱会现场哪怕100m的距离,两种感觉都是截然不同的。
       所以小G作为铁杆歌迷,也计划带着小Y去看周杰伦的演唱会。 演唱会当然要圈出一个空地,然后才能布置道具。 演唱会的第一站,公司临时跟当地的消防局借了n个栏杆,打算用这n个栏杆围出一个矩形。而麻烦的是,这些栏杆有长有短,这就给围场地带来了一些难度。 所以公司聘请你来写一个程序,计算用这n个栏杆做多围出面积多大的矩形。
(注:必须要刚好围成一个矩形,即不能出现多余的边长,且不能切断栏杆,但所给栏杆不一定要全部用上)

   2.输入数据:

  第一行一个正整数n,表示栏杆的数量。
  第二行n个正整数,表示每根栏杆的长度li。

4

    1 1 1 1

  3.输出数据:

  仅一行一个正整数,表示用给出的栏杆围成最大矩形的面积,如果不能围成矩形,输出”No Solution”(不包含引号)。

  1

  4.数据范围: 


------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

   对于这一道题,看到n<=16,应当立马想到状压,方法有很多种,上代码:

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 const int maxn=70000;
 4 int n,ans;
 5 int l[20];
 6 int f[2000],g[maxn];
 7 void judge(int sum,int bin){
 8     if(sum&1) return;//如果是奇数就不可能拆成两组相同长度
 9     memset(f,0,sizeof(f));//判断某种长度是否能刚好拆成两个相同长度的组合
10     f[0]=1;
11     for(int i=0;i<n;i++){
12         if(bin&(1<<i)){//当有第i条边的情况下
13             for(int j=sum;j>=l[i];j--){
14                 if(f[j-l[i]]) f[j]=1;//增加一条边的形式来更新f
15             }
16         }
17     }
18     if(f[sum>>1]) g[bin]=1;//如果这个长度折半也能成立,说明它可以拆成两个合法边
19 }
20 void start(){//用于构建一组合法长度
21     for(int i=1;i<(1<<n);i++){
22         int sum=0;
23         for(int j=0;j<n;j++){
24             if((1<<j)&i) sum+=l[j];
25         }
26         judge(sum,i);
27     }
28 }
29 void dfs(int o,int x1,int sum1,int x2,int sum2){
30     if(o==n){
31         if(g[x1]&&g[x2]){
32             ans=max(ans,sum1*sum2/4);
33         }
34         return;
35     }
36     dfs(o+1,x1,sum1,x2,sum2);
37     dfs(o+1,x1+(1<<o),sum1+l[o],x2,sum2);
38     dfs(o+1,x1,sum1,x2+(1<<o),sum2+l[o]);
39 }//用深搜确定最终答案
40 int main(){
41     scanf("%d",&n);
42     for(int i=0;i<n;i++) scanf("%d",&l[i]);
43     start();
44     dfs(0,0,0,0,0);
45     if(ans)
46     printf("%d",ans);
47     else printf("No Solution\n");//输出
48     return 0;
49 }

总结:

状压dp,深搜。  

原文地址:https://www.cnblogs.com/Nelson992770019/p/11145825.html

时间: 2024-10-20 00:55:16

2679.跨时代的相关文章

[状压DP][DFS]JZOJ 2679 跨时代

Description 钟逆时针而绕,恶物狰狞的倾巢,我谦卑安静地于城堡下的晚祷,压抑远古流窜的蛮荒暗号,而管风琴键高傲的说,那只是在徒劳.我的乐器在环绕,时代无法淘汰我霸气的皇朝. 你无法预言,因为我越险,翅越艳:没有句点,跨时代蔓延,翼朝天. 月下浮雕,魔鬼的浅笑,狼迎风嚎,蝠翔似黑潮,用孤独去调尊严的色调.我跨越过世代,如兽般的姿态,琴声唤起沉睡的血脉.不需要被崇拜,如兽般的悲哀,只为永恒的乐曲存在,醒过来. 去年万众瞩目的<跨时代>专辑发行之后,周杰伦又开始了他的世界巡回演唱会<

POJ 2679:Adventurous Driving(SPFA+DFS)

http://poj.org/problem?id=2679 Adventurous Driving Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 1596   Accepted: 455 Description After a period of intensive development of the transportation infrastructure, the government of Ruritania

ZOJ 2679 Old Bill(数学题)

题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2679 Among grandfather??s papers a bill was found: 72 turkeys $_679_ The first and the last digits of the number that obviously represented the total price of those turkeys are replace

POJ 2679 Adventurous Driving | SPFA + 判定负环

POJ 2679 Adventurous Driving 恶心的输入恶心的题面啊...这道题学到的东西还是蛮多的 Description..有向图..边权有两个:1.费用, 2.长度.要求找出S到T花费最小的路.一定要是花费最小....在花费最小的情况下输出路径长度的最小值..然后边权可以为负..不保证S到T一定有一条路..同时点a到点b之间可能有多条路... 总之就是..S不能到T输出VOID,S到T的路径上有负环(即没有最小值)输出UNBOUND..其他有解情况输出最小花费和最小路径长度..

ZOJ 2679 Old Bill(数学)

主题链接:problemCode=2679" target="_blank">http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2679 Among grandfather??s papers a bill was found: 72 turkeys $_679_ The first and the last digits of the number that obviously represent

UPCOJ 2679

第一个串是位置,然后第二个串可以随便跳着走,完事问可以到达的最多点数. l是左儿子能到的点数,r是右儿子能到的点数. 不被提示一下真不好写. #include <cstdio> #include <cstring> #include <vector> #include <cmath> #include <stack> #include <cstdlib> #include <queue> #include <map&

跨时代产品,TurboMail邮件系统V7.0

在互联网更加深入的发展推动下,如同互联网电视机(苹果.乐视.小米等)撼动僵化保守的电视机市场一样,企业软件市场正在经历新一代的产品洗牌,传统软件在逐渐向定制化软件和个性化服务转变. 但大家可以看到,十数年过去了,市场上的邮件系统基本没什么大的变化,仍然是老框架和传统服务,陈旧的邮件系统已经与互联网世界的变革脱节. 作为国产邮件服务器的顶级代表,TurboMail邮件系统一直走在企业邮箱技术前列,在取得了邮件服务器核心MTA的成功后,TurboMail邮件系统针对企业客户的需求正在开发可扩展.可收

【转】Windows Error Code(windows错误代码详解)

本文来自: http://blog.sina.com.cn/s/blog_5e45d1be0100i0dr.html http://blog.sina.com.cn/s/blog_5e45d1be0100i0dt.html http://blog.sina.com.cn/s/blog_5e45d1be0100i0dv.html 这三篇,因为格式实在太乱,因此拿来整理了一下.找这个的原因是今天在改程序的时候蹦出来个WindowsError: [Error 2],也没有说这个东西是什么错误.于是百度

关于过拟合、局部最小值、以及Poor Generalization的思考

Poor Generalization 这可能是实际中遇到的最多问题. 比如FC网络为什么效果比CNN差那么多啊,是不是陷入局部最小值啊?是不是过拟合啊?是不是欠拟合啊? 在操场跑步的时候,又从SVM角度思考了一下,我认为Poor Generalization属于过拟合范畴. 与我的论文 [深度神经网络在面部情感分析系统中的应用与改良] 的观点一致. SVM ImageNet 2012上出现了一个经典虐杀场景.见[知乎专栏] 里面有一段这么说道: 当时,大多数的研究小组还都在用传统compute