UVA 11401-Triangle Counting

这里写图片描述
题目链接

题目解析

题意

输入整数n,在1,2,…,n中任选3个不同的整数作为三角形的边长,求能组成多少个三角形。直到输入0时程序结束。

思路

用加法原理,设最大边长为x的三角形有c(x)个,另外2条边长分别为y和z,根据三角形不等式有y+z>x,得出z的范围为x>z>x-y。y从1取到x-1,对应的z的解的个数成等差数列,y=x-1时z有x-2个解。根据等差数列的求和公式,共有0+1+2+…+(x-3)+(x-2)=(x-1)*(x-2)/2个解。
上面的解中包含了y=z的情况,并且每个三角形算了两遍,应该扣除这2种情况。统计y=z的情况数:x>y>x-z→x>y>x-y→x>y>x/2。y的取值从(x+1)/2开始到x-1为止,一共有x-1-(x+1)/2+1=(x-1)/2个解。
这里写图片描述

代码
#include<stdio.h>
#define MAX 1000000
#define LL long long
    LL f[MAX+10];
int main(){
    f[3]=0;
    for(LL x=4;x<=MAX;x++)
        f[x]=f[x-1]+((x-1)*(x-2)/2-(x-1)/2)/2;//或是f[x]=f[x-1]+((x-1)*(x-2)/2-(x-2)/2)/2;
    int n;
    while(~scanf("%d",&n),n>=3)
        printf("%lld\n",f[n]);
    return 0;
} 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 根据三角形不等式,我们可以编写一段C语言代码来判断三条线段的长度能否组成三角形,如果不能,则输出No,如果能,请判断此三角形是否为等边三角形,若是则输出E-Triangle,否则输出G-Triangle。以下是编写的C语言程序:#include<stdio.h> int main() { int a,b,c; scanf("%d %d %d",&a,&b,&c); if(a+b>c && a+c>b && b+c>a) { if(a==b && a==c) printf("E-Triangle"); else printf("G-Triangle"); } else printf("No"); return 0; } ### 回答2: 可以通过以下步骤来判断三条线段能否组成三角形,并判断是否为等边三角形: 1. 首先,输入三个整数表示三条线段的长度,分别为a、b和c。 2. 判断三个数是否大于0,若有任一条线段长度小于等于0,则输出"No"。 3. 判断是否满足三角形的三边关系,即任意两边之和大于第三边。若不满足该条件,则输出"No"。 4. 判断是否为等边三角形,若三个数都相等,则输出"E-Triangle";否则,输出"G-Triangle"。 以下是对应的C语言代码实现: ```c #include<stdio.h> int main() { int a, b, c; // 输入三个整数 printf("请输入三个整数,分别表示三条线段的长度:\n"); scanf("%d%d%d", &a, &b, &c); // 判断三角形是否合法 if (a <= 0 || b <= 0 || c <= 0 || (a+b <= c) || (a+c <= b) || (b+c <= a)) { printf("No\n"); } else { // 判断是否为等边三角形 if (a == b && b == c) { printf("E-Triangle\n"); } else { printf("G-Triangle\n"); } } return 0; } ``` 该程序首先通过`scanf`函数输入三个整数,判断是否满足三角形的三边关系,并判断是否为等边三角形,并输出相应结果。 ### 回答3: 可以根据三角形的性质来判断三条线段能否组成一个三角形。三角形的任意两边之和大于第三边,任意两边之差小于第三边。所以我们可以编写一个判断三角形的函数。再判断是否为等边三角形。 首先,定义一个函数isTriangle(int a, int b, int c),用于判断三条边a、b、c能否组成一个三角形: ```c int isTriangle(int a, int b, int c) { if (a + b > c && a + c > b && b + c > a) { return 1; } else { return 0; } } ``` 再定义一个函数isEquilateral(int a, int b, int c),用于判断三角形是否为等边三角形: ```c int isEquilateral(int a, int b, int c) { if (a == b && b == c) { return 1; } else { return 0; } } ``` 在主函数中,读入三个整数表示三条线段的长度,调用isTriangle函数判断是否为三角形,如果不是则输出"No",否则调用isEquilateral函数判断是否为等边三角形,如果是则输出"E-Triangle",否则输出"G-Triangle"。 ```c #include <stdio.h> int isTriangle(int a, int b, int c) { if (a + b > c && a + c > b && b + c > a) { return 1; } else { return 0; } } int isEquilateral(int a, int b, int c) { if (a == b && b == c) { return 1; } else { return 0; } } int main() { int a, b, c; printf("请输入三条线段的长度:"); scanf("%d %d %d", &a, &b, &c); if (!isTriangle(a, b, c)) { printf("No\n"); } else if (isEquilateral(a, b, c)) { printf("E-Triangle\n"); } else { printf("G-Triangle\n"); } return 0; } ``` 以上就是判断三条线段是否能组成三角形以及是否为等边三角形的C语言程序。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值