bzoj 1600 & Usaco 月赛 2008 建造栅栏 题解

【原题】

1600: [Usaco2008 Oct]建造栅栏

Time Limit: 5 Sec   Memory Limit: 64 MB
Submit: 785   Solved: 443
[ Submit][ Status]

Description

勤奋的Farmer John想要建造一个四面的栅栏来关住牛们。他有一块长为n(4<=n<=2500)的木板,他想把这块本板切成4块。这四块小木板可以是任何一个长度只要Farmer John能够把它们围成一个合理的四边形。他能够切出多少种不同的合理方案。注意: *只要大木板的切割点不同就当成是不同的方案(像全排列那样),不要担心另外的特殊情况,go ahead。 *栅栏的面积要大于0. *输出保证答案在longint范围内。 *整块木板都要用完。

Input

*第一行:一个数n

Output

*第一行:合理的方案总数

Sample Input

6

Sample Output

6


输出详解:

Farmer John能够切出所有的情况为: (1, 1, 1,3); (1, 1, 2, 2); (1, 1, 3, 1); (1, 2, 1, 2); (1, 2, 2, 1); (1, 3,1, 1);
(2, 1, 1, 2); (2, 1, 2, 1); (2, 2, 1, 1); or (3, 1, 1, 1).
下面四种 -- (1, 1, 1, 3), (1, 1, 3, 1), (1, 3, 1, 1), and (3,1, 1, 1) – 不能够组成一个四边形.

HINT

Source


【分析】这道题的标算不太清楚,可能是DP吧。看到这类题目,就二话不说先打表。

我默认四边形的成立条件:三边之和大于第四边。

#include<cstdio>
using namespace std;
int n,i,j,k,p,ans;
int main()
{
  for (n=1;n<=50;n++)
  {
  ans=0;
  for (i=1;i<(n+1)/2;i++)
    for (j=1;j<(n+1)/2;j++)
      for (k=1;k<(n+1)/2;k++)
        if (i+j+k<n) 
        {
          p=n-i-j-k;
          if (i+j+k<=p||i+j+p<=k||i+k+p<=j||j+k+p<=i) continue;
          ans++;
        }
  printf("%d ",ans);
  }
  for (;;);
}

话说我的打表程序好丑啊。然后这是1--20的情况:

0   0   0   1   4   6   16   19   40   44   80   85   140   146   224   231   336   344   480   489

看有什么规律。我先发现隔一位的规律:0和1差1,4和6差2,16和19差3。以此类推。

现在的关键就是求另外一组相邻的关系。作差后可得:3  10  21  36  55……发现规律了吗?这有两种形式来描述:①3=1+2,10=1+2+3+4,21=1+2+3+4+5+6,……②3=1*3,10=2*5,21=3*7,36=4*9 

自此,我们把规律整理一下就行了。

【AC代码】

#include<cstdio>
using namespace std;
int n,i,f[2505];
int main()
{
  scanf("%d",&n);
  if (n<4) {puts("0");return 0;}
  f[4]=1;
  for (i=5;i<=n;i++)
    if (!(i&1)) f[i]=f[i-1]+i/2-1;
    else f[i]=f[i-1]+(i-2)*(i/2-1);
  printf("%d",f[n]);
  return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
USB-IF高速;,经认证符合通用串行总线规范修订版 2.0 接口在 8 位模式下与 ULPI 规范修订版 1.1 兼容 工业标准 UTMI+ 低引脚接口 (ULPI) 可将 54 UTMI+ 信号转换为标准的 12 引脚链路控制器接口 54.7mA 未配置电流(典型情况)— 适用于总线供电的应用 83uA 挂起电流(典型情况)— 适用于电池供电的应用 闭锁性能超过 150 mA(每 EIA/JESD 78),Class II ESD 防护水平达 ±8kV HBM(在不使用外部保护设备的情况下) 集成了各种保护措施,在每个第三方的测试设备中均可耐受 IEC61000-4-2 ESD 测试(±8kV 接触电压和 ±15kV 空气电压) 支持用于附带 LS 设备的 FS 集线器的 FS 前导码 (UTMI+ Level 3) 支持 HS SOF 和 LS keep-alive 脉冲 包括对可选的 On-The-Go (OTG) 协议的全面支持,在 On-The-Go 附录修订版 1.0a 规范中有详细说明 支持 OTG 主机协商协议 (HNP) 和会话请求协议 (SRP) 允许主机关闭 VBUS,以便在 OTG 应用中节省电池电量 通过内部比较器支持 VBUS 电平的 OTG 监视。包括对外部 VBUS 或故障监视器的支持。 低潜伏高速接收器(最高为 43 高速时钟)允许使用带 ULPI 包装器的潜伏 UTMI 链路 用于接口保护的 STP 上的集成下拉电阻,允许在使用低速链路(针对低功率情况对软件进行了配置)的情况下,可靠地启动 Link/PHY 内置的 1.8V 调节器允许在使用单个 3.3V 电源的情况下工作 对 ID、DP 和 DM 线路到 VBUS 或接地进行内部短路保护 集成的 24MHz 晶振支持水晶操作或 24MHz 外部时钟输入 用于 480MHz 高速 USB 操作的内部 PLL 工业运行温度:-40°C 到 +85°C 符合 RoHS 的 32 引脚无铅 QFN 封装(5 x 5 毫米, 高度为 0.90 毫米)

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值