Triangle Counting

Input: Standard Input

Output: Standard Output

You are given n rods of length 1, 2…, n. You have to pick any 3 of them & build a triangle. How many distinct triangles can you make? Note that, two triangles will be considered different if they have at least 1 pair of arms with different length.

Input

The input for each case will have only a single positive integer (3<=n<=1000000). The end of input will be indicated by a case with n<3. This case should not be processed.

Output

 

For each test case, print the number of distinct triangles you can make.

Sample Input                                                  Output for Sample Input

5

8

0

3

22

题目描述:

有多少种方法可以从1,2,3,,,,n中选出三个不同的整数,可以组成三角形。

1 数学分析:

设最大边长为x的三角形与c[x]个。

y+z>x;

x-y<z<x;

枚举y的长度,就可以得到z的个数。

y==1,z无解;

y==2,z=x-1;

y==3,z=x-1 ,x-2;

......

y=x-1,z=2,3,4,,,x-1;

等差数列求和.(x-1)*(x-2)/2;

去除y==z,和重复计算的种类.

y==z有多少种呢?

y的取值从x/2+1开始到x-1为止,因为这样也能组成三角形。

c[x]=( (x-1)(x-2)/2-(x-1)/2 ) 、2;

f[x]=f[x-1]+c[x];

2  直接观察:

n为偶数时:

2 n-1 (1)

3 n-2  (2)

4 n-3

......

m  m+1 (n-m-1)

m+1 m+2 (n-m-2)

.....

n-2 n-1   1

f[i]=f[i-1]+(i*i-4*i+4)/4;利用等差数列求和

n为奇数时:

2 n-1 (1)

3 n-2  (2)

4 n-3

......

m  m+2 (n-m-2)

m+1 m+2 (n-m-2)

.....

n-2 n-1   1

f[i]=f[i-1]+(i-i/2-1) * (i-3) /2;

#include<stdio.h>
typedef long long i64;
long long f[1000000];
void solve()
{ f[3]=0;
for(long long i=4;i<=1000000;i++)
{
f[i]=0;
if( (i & 1)==0 ) //i为偶数
f[i]=f[i-1]+(i*i-4*i+4)/4;
else
f[i]=f[i-1]+(i-i/2-1) * (i-3) /2;
} }
int main()
{
solve();
int n;
while(scanf("%lld",&n)!=EOF&&n>=3)
{
printf("%lld\n",f[n]);
}
return 0;
}

  

/*
设最大边长为x的三角形有c(x)个,跟三角形的定义两边之和大于第三边有x<y+z
变形下的x-y<z<x;当y=1时无解,当y=2时只有一个解z=x-1,知道y=x-1时又x-2个解
,所以共有(x-1)(x-2)/2个解,由于题意中不能存在y=z的解所以y=z这部分解,
当x/2+1至x-1才存在y=z的可能,共有(x-1)/2个.还过有过程中每种三角形算了两遍
所以c(x)=((x-1)(x-2)/2-(x-1)/2)/2);
f(n)=c(1)+c(2)+.....+c(n);
*/
#include<iostream>
#include<cstdio>
using namespace std;
__int64 f[]; void Init()
{
__int64 i;//用int定义结果Wrong answer,不定义__int64计算过程中会溢出
f[]=;
f[]=;
f[]=;
for(i=;i<=;i++)
f[i]=f[i-]+((i-)*(i-)/-(i-)/)/;
} int main()
{
Init();
int n;
while(cin>>n,n>=)
printf("%I64d\n",f[n]);
return ;
}

uva 11401的更多相关文章

  1. uva 11401 Triangle Counting

    // uva 11401 Triangle Counting // // 题目大意: // // 求n范围内,任意选三个不同的数,能组成三角形的个数 // // 解题方法: // // 我们设三角巷的 ...

  2. Uva 11401 数三角形

    题目链接:https://uva.onlinejudge.org/external/114/11401.pdf 题意:1~n个数里面挑3个不同的数,组成一个三角形.求方案数. 分析: 令最长的边为X, ...

  3. 【UVA 11401】Triangle Counting

    题 题意 求1到n长度的n根棍子(3≤n≤1000000)能组成多少不同三角形. 分析 我看大家的递推公式都是 a[i]=a[i-1]+ ((i-1)*(i-2)/2-(i-1)/2)/2; 以i 为 ...

  4. UVA 11401 - Triangle CountingTriangle Counting 数学

    You are given n rods of length 1,2, . . . , n. You have to pick any 3 of them and build a triangle. ...

  5. UVa 11401 三角形的个数

    题意:由1,2,3...n组成的序列中找三个数,且以这三个数为变长能组成三角形,求这样的三角形个数. 思路:当每次输入n时重新都计算一遍会TLE...先预处理,将结果存入ans数组. 代码: #inc ...

  6. Triangle Counting UVA - 11401(递推)

    大白书讲的很好.. #include <iostream> #include <cstring> using namespace std; typedef long long ...

  7. 【递推】【组合计数】UVA - 11401 - Triangle Counting

    http://blog.csdn.net/highacm/article/details/8629173 题目大意:计算从1,2,3,...,n中选出3个不同的整数,使得以它们为边长可以构成三角形的个 ...

  8. UVa 11401 Triangle Counting (计数DP)

    题意:给定一个数 n,从1-n这些数中任意挑出3个数,能组成三角形的数目. 析:dp[i] 表示从1-i 个中任意挑出3个数,能组成三角形的数目. 代码如下: #pragma comment(link ...

  9. UVA计数方法练习[3]

    UVA - 11538 Chess Queen 题意:n*m放置两个互相攻击的后的方案数 分开讨论行 列 两条对角线 一个求和式 可以化简后计算 // // main.cpp // uva11538 ...

随机推荐

  1. SPOJ DCEPC11I

    题目大意: 就是给定一段区间令其中的数增加一个递增序列(也就是说第一个+1,第二个+2.....) 询问操作是区间的和 这里的查询很简单,但是对于添加递增序列入区间就比较搞脑子了 我们需要一个add[ ...

  2. BZOJ 1221: [HNOI2001] 软件开发【最小费用最大流】

    Description 某软件公司正在规划一项n天的软件开发计划,根据开发计划第i天需要ni个软件开发人员,为了提高软件开发人员的效率,公司给软件人员提供了很多的服务,其中一项服务就是要为每个开发人员 ...

  3. Java多线程干货系列—(二)synchronized

    原文地址:http://tengj.top/2016/05/03/threadsynchronized2/ <h1 id="前言"><a href="# ...

  4. [CodePlus2017]晨跑

    Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 166  Solved: 125 Description "无体育,不清华".&qu ...

  5. php统计图类库JpGraph

    php统计图类库JpGraph JpGraph官网地址:https://jpgraph.net/. (1)下载类库: 下载地址:https://jpgraph.net/download/. 选择版本, ...

  6. [Bzoj1030][JSOI2007]文本生成器(AC自动机)(dp)

    1030: [JSOI2007]文本生成器 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 5254  Solved: 2172[Submit][Stat ...

  7. HDU 1024 【DP】

    题意: 给n个数将其分成连续的m组,使得这些组的数加和最大,组与组之间可以空数. /* dp[i][j]表示将前j个数分成i个组最大值 状态转移方程是: dp[i][j]=max(dp[i-1][0. ...

  8. Python---django轻量级框架

    Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Session等诸多功能. ...

  9. Eclipse打war包方法以及Eclipse移植项目时JDK版本不匹配Project facet Java version 1.7 is not supported

    打包时: 在项目上右键选择Export,如图: 然后选择WAR file,如图所示.接着再:其中web projecct为打出来包的名字, Destination,打包后存的位置,点击Browse.. ...

  10. 【SDCC讲师专访】PingCAP联合创始人兼CEO刘奇:好的产品应开源,不闭门造车-CSDN.NET

    [SDCC讲师专访]PingCAP联合创始人兼CEO刘奇:好的产品应开源,不闭门造车-CSDN.NET 小米的Themis