传送门 http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1509

现在有三根木棒,他们的长度分别是a,b,c厘米。你可以对他们进行加长(不同的木棒可以增加不同的长度),他们总的加长长度不能超过L厘米。你也可以不对他们进行加长。

现在请你计算一下有多少种加长的方式使得他们能构成合法的三角形(面积非0)。

Input
单组测试数据。
共一行,包含4 个整数a,b,c,L (1≤a,b,c≤3*10^5, 0≤L≤3*10^5)。
Output
输出答案占一行。
Input示例
1 1 1 2
Output示例
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加长棒的更多相关文章

  1. 51Nod 1509 加长棒(隔板法)

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1509 思路: 直接去解可行的方法有点麻烦,所以应该用总的方法去减去不可行 ...

  2. 51 Nod 1509 加长棒(巧妙的隔板法计数)

    1509 加长棒  题目来源: CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题  收藏  关注 现在有三根木棒,他们的长度分别是a,b,c厘米 ...

  3. Good Vegetable 4级算法题 分值: [320/3120] 问题: [8/78]

    1523 非回文 题目来源: CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 收藏 关注 一个字符串是非回文的,当且仅当,他只由前p个小写字母 ...

  4. 【题解】51nod 1203JZPLCM问题

    这题好强强啊,貌似是集训队原题?集训队原题当中值域是1e9的范围,这样各种乱搞是妥妥的不能过了,只能写正解的离线+树状数组维护前缀积. 最开始我写了几种乱搞做法,包括莫队和线段树做法.其中表现比较优秀 ...

  5. 51nod 1402 最大值(贪心)

    原题链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1402 思路:借鉴了这篇博文http://blog.csdn.n ...

  6. 8个超棒的HTML5网站设计欣赏

    我们听到了很多关于HTML5的新闻和技术动向,一个又一个的新的东西不停的出现,那么最近HTML5的技术应用又如何呢?HTML5又和CSS及其Javascript如何一起改变我们的网站设计和实现的呢? ...

  7. 【51Nod 1244】莫比乌斯函数之和

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1244 模板题... 杜教筛和基于质因子分解的筛法都写了一下模板. 杜教筛 ...

  8. 51Nod 1268 和为K的组合

    51Nod  1268  和为K的组合 1268 和为K的组合 基准时间限制:1 秒 空间限制:131072 KB 分值: 20 难度:3级算法题 给出N个正整数组成的数组A,求能否从中选出若干个,使 ...

  9. 51Nod 1428 活动安排问题

    51Nod   1428  活动安排问题 Link: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1428 1428 活 ...

随机推荐

  1. 开涛spring3(4.2) - 资源 之 4.2 内置Resource实现

    4.2  内置Resource实现 4.2.1  ByteArrayResource ByteArrayResource代表byte[]数组资源,对于“getInputStream”操作将返回一个By ...

  2. jquery和vue对比

    1.jquery介绍:想必大家都用过jquery吧,这个曾经也是现在依然最流行的web前端js库,可是现在无论是国内还是国外他的使用率正在渐渐被其他的js库所代替,随着浏览器厂商对HTML5规范统一遵 ...

  3. 基于dubbo的SSM(Spring,SpringMvc,Mybatis)整合的Maven多工程(下)

    上篇是SSM的maven单工程(http://www.cnblogs.com/yuanjava/p/6748956.html).中篇是 SSM的maven多工程(http://www.cnblogs. ...

  4. 日志组件二:log4j2

    一.背景 随着业务服务(Server App)逐渐增加,我们的业务系统中的日志输出面临的问题越来越多,高并发下对磁盘io这块消耗的越来越大,因此,急需要一个高性能且最好能够支持异步输出日志的日志框架, ...

  5. iOS11和机器学习CoreML库

    随着iOS11的发布,苹果公司也正式加入了机器学习的战场.在新的iOS11中内置了CoreML,虽然还是Beta版本,但是功能已经非常强大了. 在这个CoreML库里面,已经集成了一些训练好的模型,可 ...

  6. 并发容器ConcurrentHashMap#put方法解析

    jdk1.7.0_79 HashMap可以说是每个Java程序员用的最多的数据结构之一了,无处不见它的身影.关于HashMap,通常也能说出它不是线程安全的.这篇文章要提到的是在多线程并发环境下的Ha ...

  7. Android布局方式

    1. LinearLayout(线性布局)     android:orientation="vertical"    android:layout_width="wra ...

  8. 常用数组、字符串方法总结&获取元素、DOM操作

    字符串的方法.返回值.是否改变原字符串:1 charAt() 方法可返回指定位置的字符. 不改变原始字符串 JavaScript并没有一种有别于字符串类型的字符数据类型,返回的字符是长度为 1 的字符 ...

  9. APP热更新方案

    为什么要做热更新 当一个App发布之后,突然发现了一个严重bug需要进行紧急修复,这时候公司各方就会忙得焦头烂额:重新打包App.测试.向各个应用市场和渠道换包.提示用户升级.用户下载.覆盖安装. 重 ...

  10. .NET 开发环境搭建

    概述 在接下来的时间里,将会入手ASP.NET MVC这一专题,尽量用最快的时间,最有效的方法,分别从深度和广度上剖析这一专题,力求讲明白.讲透.以此来与大家分享,力求达到共同学习,共同交流,共同进步 ...