51Nod 1509加长棒
传送门 http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1509
现在有三根木棒,他们的长度分别是a,b,c厘米。你可以对他们进行加长(不同的木棒可以增加不同的长度),他们总的加长长度不能超过L厘米。你也可以不对他们进行加长。
现在请你计算一下有多少种加长的方式使得他们能构成合法的三角形(面积非0)。
单组测试数据。
共一行,包含4 个整数a,b,c,L (1≤a,b,c≤3*10^5, 0≤L≤3*10^5)。
输出答案占一行。
1 1 1 2
4
这个题我被坑了很久,搞了2.5小时以上了才AC,不过AC的时候真TM爽!(然而岑神几分钟就做对了ORZ)其实很早就有思路了,但是计算的公式疏忽了好几个地方,最后还是下载了部分数据才过的
办法是枚举加长a的量(设其为i),剩余的可用长度为w,很容易得出在不考虑构成三角形的情况下,总共有(w+1)*(w+2)/2种方案,如果减去其中不合法的种数就是a加长量为i的时候的合法方案数了。
不合法的方案有3种,a太长,b太长,c太长(这里说的a,b,c是已经加长后的长度)
针对a太长,我们设x=min(w,a+i-b-c),换句话讲,就是即使给b,c加上共计为x的长度,依然不合法,这种情况数为(x+2)*(x+1)/2
针对b太长或者c太长,其实这两种情况是差不多的,我们设x=w+b-a-c-i(b太长),x=w+c-a-b-i(c太长),思路是先假设b被加到了b+w,然后减掉b中的一部分,把那一部分中的一部分加到c上
然后分三种情况讨论
情况一.w<=x/2 也就是就算把原来加到b上去的长度全卸下来,并且全加到c上去,b还是太长,那么这里的操作是ans-=(1+w)*(w+2)/2;
情况二.w>=x 这种情况下w不会限制我们把b的一部分长度卸下来,操作是ans-=(2+x/2)*(1+x/2)/2,ans-=(x-x/2)*(1+x-x/2)/2;
情况三.x/2<w<x 这种情况下w会限制我们把b的一部分长度卸下来,操作是ans-=(2+x/2)*(1+x/2)/2,ans-=(w-x/2)*(x-x/2+x-w+1)/2;
#include<string>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cmath>
#include<vector>
#include<queue>
using namespace std;
typedef long long ll;
int main()
{
ll i,j;
ll a,b,c,L;
scanf("%lld%lld%lld%lld",&a,&b,&c,&L);
ll ans=;
if(a+b+L<=c||a+c+L<=b||b+c+L<=a)
{
printf("0\n");
return ;
}
for(i=;i<=L;i++)
{
ll w=L-i;
if(a+i>=b+c+w)break;
ans+=(w+)*(w+)/;//√
if(a+i>=b+c)
{
ll x=min(a-b-c+i,w);
ans-=(x+)*(x+)/;//√
}
if(w+b>=a+c+i)
{
ll x=w+b-a-c-i;
if(x<=w)
{
ans-=(+x/)*(+x/)/;
ans-=(x-x/)*(+x-x/)/;
}
else if(w<x)
{
if(w<=x/)
{
ans-=(+w)*(w+)/;
}
else
{
ans-=(+x/)*(+x/)/;
ans-=(w-x/)*(x-x/+x-w+)/;
}
}
}
if(w+c>=a+b+i)
{
ll x=w+c-a-b-i;
if(x<=w)
{
ans-=(+x/)*(+x/)/;
ans-=(x-x/)*(+x-x/)/;
}
else if(w<x)
{
if(w<=x/)
{
ans-=(+w)*(w+)/;
}
else
{
ans-=(+x/)*(+x/)/;
ans-=(w-x/)*(x-x/+x-w+)/;
}
}
}
}
printf("%lld\n",ans);
return ;
}
/*
17 28 19 5558
*/
/*
7396315389 */
/*
100000 300000 100000 100003
*/
/*
400012
*/
51Nod 1509加长棒的更多相关文章
- 51Nod 1509 加长棒(隔板法)
http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1509 思路: 直接去解可行的方法有点麻烦,所以应该用总的方法去减去不可行 ...
- 51 Nod 1509 加长棒(巧妙的隔板法计数)
1509 加长棒 题目来源: CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 收藏 关注 现在有三根木棒,他们的长度分别是a,b,c厘米 ...
- Good Vegetable 4级算法题 分值: [320/3120] 问题: [8/78]
1523 非回文 题目来源: CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 收藏 关注 一个字符串是非回文的,当且仅当,他只由前p个小写字母 ...
- 【题解】51nod 1203JZPLCM问题
这题好强强啊,貌似是集训队原题?集训队原题当中值域是1e9的范围,这样各种乱搞是妥妥的不能过了,只能写正解的离线+树状数组维护前缀积. 最开始我写了几种乱搞做法,包括莫队和线段树做法.其中表现比较优秀 ...
- 51nod 1402 最大值(贪心)
原题链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1402 思路:借鉴了这篇博文http://blog.csdn.n ...
- 8个超棒的HTML5网站设计欣赏
我们听到了很多关于HTML5的新闻和技术动向,一个又一个的新的东西不停的出现,那么最近HTML5的技术应用又如何呢?HTML5又和CSS及其Javascript如何一起改变我们的网站设计和实现的呢? ...
- 【51Nod 1244】莫比乌斯函数之和
http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1244 模板题... 杜教筛和基于质因子分解的筛法都写了一下模板. 杜教筛 ...
- 51Nod 1268 和为K的组合
51Nod 1268 和为K的组合 1268 和为K的组合 基准时间限制:1 秒 空间限制:131072 KB 分值: 20 难度:3级算法题 给出N个正整数组成的数组A,求能否从中选出若干个,使 ...
- 51Nod 1428 活动安排问题
51Nod 1428 活动安排问题 Link: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1428 1428 活 ...
随机推荐
- poi解析excel
一.遇见的问题: 当单元格设置为日期类型时,cell.getCellStyle().getDataFormat()返回的值都为176. poi jar包3.14以上不支持用cell.getCellTy ...
- MySQL主从搭建
主服务器配置 1.编辑配置文件 # 如果不存在,就手动创建一个 vim /etc/my.cnf 在配置文件加入如下值: [mysqld] # 唯一的服务辨识号,数值位于 1 到 2^32-1之间. # ...
- 一个html页面传入参数到另一个html页面用js获取方法
没错使用以下函数就能够完整的获取到路径里的你想要的参数:function getURLParameter(name) { return decodeURIComponent((new RegExp(' ...
- 几个页面loading样式
随手练习了几个loading样式,以后看到有意思的loading样式也会补充上.样式的兼容性建议还是去w3c上看下属性的兼容性,至少我习惯这么多,当然,w3c中文网貌似很久很久没更新过了,可能更好的还 ...
- Xmpp学习之Android-smack入门指导
Xmpp学习之Android-smack入门指导 版权声明:本文为博主原创文章,未经博主允许不得转载. 转载请表明出处:http://www.cnblogs.com/cavalier-/p/69404 ...
- (原创)用Java实现链表结构对象:单向无环链表
转载请注明本文出处:http://www.cnblogs.com/Starshot/p/6918569.html 链表的结构是由一个一个节点组成的,所谓链,就是每个节点的头尾连在一起.而单向链表就是: ...
- 模板C++ 03图论算法 2最短路之全源最短路(Floyd)
3.2最短路之全源最短路(Floyd) 这个算法用于求所有点对的最短距离.比调用n次SPFA的优点在于代码简单,时间复杂度为O(n^3).[无法计算含有负环的图] 依次扫描每一点(k),并以该点作为中 ...
- iOS项目评估报告
1.整体项目无分层概念,结构混乱,代码耦合严重. 影响:后期扩展困难,维护困难. 解决方案:1.整体采用mvc模式. 2.在原来的基础再抽离出业务层 3.业务层按模块管理,合理分层分包. 4.做好共用 ...
- node.js入门系列(一)--Node.js简介
什么是NodeJS JS是脚本语言,脚本语言都需要一个解析器才能运行.对于写在HTML页面里的JS,浏览器充当了解析器的角色.而对于需要独立运行的JS,NodeJS就是一个解析器. 每一种解析器都是一 ...
- ActiveMQ 学习第二弹
经历了昨天的初识 ActiveMQ,正好今天下班有点事耽搁了还没法回家,那就再学习会 ActiveMQ 吧!现在官网的文档没啥好看的了,毕竟是入门学习,太深奥的东西也理解不了.然后看官网上有推荐书籍& ...