判断三角形的c语言
1. c语言 判断三角形的类型
#include<stdio.h>
int
main(){
float
a,b,c,temp;
do{
printf("Please
input
a,b,c:\n");
scanf("%f%f%f",&a,&b,&c);
/*对a,b,c从小到大排序*/
if(a>b){temp=a;a=b;b=temp;}
if(a>c){temp=a;a=c;c=temp;}
if(b>c){temp=b;b=c;c=temp;}
if(a+b>c)break;
else
{printf("三角形不成立\n");}
}while(1);
if(a==b&b==c)printf("等边三角形\n");
else
if(a==b)
if(a*a+b*b==c*c)printf("等腰直角三角形\n");
else
printf("等腰三角形\n");
else
if(a*a+b*b==c*c)printf("直角三角形\n");
else
printf("一般三角形\n");
}
你可以试验一下,基本满足要求,只有等腰直角三角形,不好测试,因为肯定有边是带根号的
无法输入根号的数据啊
2. C语言,怎么编程判断三角形的形状
从小到大排序:a<=b<= c
如果a+b>c,是三角形,否则不是三角形[三角形两边之和大于第三边]
三边相等:等边三角形
两边相等:等腰三角形
a*a+b*b=c*c:直角三角形
3. 怎样用C语言判断三角形类型(等边,等腰,直角,等腰直角)
#include<stdio.h>
main()
{
doublea[3],b;
while(1){
scanf("%lf%lf%lf",&a[0],&a[1],&a[2]);//输入三边
if(a[0]>0&&a[1]>0&&a[2]>0){//三边中任何一边都得大于0
if(a[0]<a[1]){b=a[0];a[0]=a[1];a[1]=b;}//将最大的边交换到a[0]中
if(a[0]<a[2]){b=a[0];a[0]=a[2];a[2]=b;}
if(a[1]+a[2]<=a[0]){
printf("不是三角形
");continue;}//两个短边之和不大于第三边,不是三角形
if(((int)(a[1]*a[1])+(int)(a[2]*a[2])==(int)(a[0]*a[0]))&&(a[0]==a[1]||a[1]==a[2]||a[0]==a[1])){
printf("等腰直角三角形
");continue;}//两个短边的平方=长边的平方就是直角
if((int)(a[1]*a[1])+(int)(a[2]*a[2])==(int)(a[0]*a[0])){
printf("直角三角形
");continue;}
if(a[0]==a[1]&&a[0]==a[2]){
printf("等边三角形
");continue;}
if(a[0]==a[1]||a[1]==a[2]||a[0]==a[1]){
printf("等腰三角形
");continue;}
}else
printf("不是三角形
");
}
}
//这里计算直角三角形时,转成int在进行比较,是为了降低精度,特别是计算等腰直角三角形,
//根号2,是无限的小数,不降低精度很难能得到的相等关系的。
如图所示,望采纳。。。。。。
4. c语言如何判断abc能否构成三角形
#include <stdio.h>
int main()
{
float a,b,c;
printf("请输入三边的边长:");
scanf("%f%f%f",&a,&b,&c);
if(a>0 && b>0 &&c>0)
{
if(a+b>c && a+c>b &&b+c>a)
{
printf("(%.2f,%.2f,%.2f)能围成三角形\n",a,b,c);
}
else
{
printf("(%.2f,%2.2f,%.2f)不能围成三角形\n",a,b,c);
}
}
return 0;
}
判断三角形类型。输入三角形的三条边a,b,c,判断它们能否构成三角形。若能构成三角形,指出是何种三角形(等腰三角形、等边三角形、直角三角形、等腰直角三角形、一般三角形),计算精度:1E-1。
输入提示信息:“Input a,b,c:”
输入格式:"%f,%f,%f"。
5. 用c语言判断三角形
判断三角形---抛砖引玉参考资料:http://tieba..com/p/482306039
#include<stdio.h>
#include<stdlib.h>
voidinput(int&a,int&b,int&c)
{
printf("inputthea=");
scanf("%d",&a);
printf(" ");
printf("inputtheb=");
scanf("%d",&b);
printf(" ");
printf("inputthec=");
scanf("%d",&c);
printf(" ");
}
intpanan(inta,intb,intc)
{
if(a>=100&&a<=1)
{
return0;
exit(0);
}
if(b>=100&&b<=1)
{
return0;
exit(0);
}
if(c>=100&&c<=1)
{
return0;
exit(0);
}
if(a<b+c)
if(b<a+c)
if(c<a+b)
return4;
else
return0;
}
voidleixing(inti)
{
switch(i)
{
case'0':
printf("a,b,c不能组成一个三角形! ");
case'1':
printf("a,b,c组成了一个等边三角形! ");
case'2':
printf("a,b,c组成了一个等腰三角形! ");
case'3':
printf("a,b,c组成了一个直角三角形! ");
case'4':
printf("a,b,c组成一个普通的三角形! ");
default:
printf("a,b,c组成一个普通的三角形! ");
}
}
intdengbian(inta,intb,intc)
{
if(a==b)
if(b==c)
return1;
else
return0;
}
intdengyao(inta,intb,intc)
{
if(a==b||b==c||c==a)
return2;
else
return0;
}
intjiao(inta,intb,intc)
{
if((a*a)==(b*b)+(c*c))
{
return3;
exit(0);
}
if((b*b)==(c*c)+(a*a))
{
return3;
exit(0);
}
if((c*c)==(b*b)+(a*a))
{
return3;
exit(0);
}
else
return0;
}
intxingzhuang(inta,intb,intc)
{
inttemp=0;
temp=dengbian(a,b,c);
if(temp)
{
returntemp;
exit(0);
}
temp=dengyao(a,b,c);
if(temp)
{
returntemp;
exit(0);
}
temp=jiao(a,b,c);
if(temp)
{
returntemp;
exit(0);
}
else
return1;
}
voidmain()
{
inta,b,c;
inttemp;
input(a,b,c);
//printf("%d%d%d",a,b,c);
temp=panan(a,b,c);
//printf("%d",temp);
if(temp==1)
{
temp=xingzhuang(a,b,c);
//printf("%d",temp);
leixing(temp);
}
else
leixing(temp);
}
6. C语言判断三角形
#include<stdio.h>
voidBubbleSort(int*pData,intcount)
{
inttemp;
for(inti=1;i<count;i++)
{
for(intj=count-1;j>=i;j--)
{
if(pData[j]<pData[j-1])
{
temp=pData[j-1];
pData[j-1]=pData[j];
pData[j]=temp;
}
}
}
}
intmain()
{
intdata[3]={0};
printf("输入: ");
for(inti=0;i<3;i++)
{
scanf_s("%d",data+i);
}
BubbleSort(data,3);
inta=data[0],b=data[1],c=data[2];
if(a+b>c&&b-a<c)
{
printf("能构成三角形 ");
if((a^2)+(b^2)<(c^2))
{
if(a==b||a==c||b==c)
{
if(a==b==c)
{
printf("等边三角形 ");
}
printf("等腰三角形 ");
}
printf("锐角三角形 ");
}
elseif((a^2)+(b^2)==(c^2))
{
printf("直角三角形 ");
}
else
printf("钝角三角形 ");
}
return0;
}
7. C语言怎么编程判断三角形的形状
代码如下:
#include <stdio.h>
#include <stdlib.h>
#defineEPSINON1e-3
#defineABS(a)(((a)>0)?(a):(-a)) //?:不支持表达式嵌套
#define ZERO(x)((x)>-EPSINON && (x)<EPSINON)
#define MAX(a,b)(((a)>(b))?(a):(b))
#define MIN(a,b)(((a)<(b))?(a):(b))
float a, b, c;
float max, mid, min;
char input_err_flag = 0;
char judge_err_flag = 0;
int equal(float a, float b)
{
float tmp;
tmp = a - b;
tmp = ZERO(ABS(tmp));
return tmp;
}
void input(void)
{
a = b = c = 0;
printf("输入三条边的值:");
scanf("%f %f %f",&a, &b, &c);
if(!(a>0) || !(b>0) || !(c>0))
{
input_err_flag = 1;
}
}
void sort(void)
{
max = MAX(MAX(a,b),c);
min = MIN(MIN(a,b),c);
if(MAX(a,b) < c)
mid = MAX(a,b);
else
mid = MAX(MIN(a,b),c);
}
void judge(void)
{
float max_square, mid_square, min_square, tmp;
if(max >= (mid+min))
{
judge_err_flag = 1;
}
else
{
max_square = max * max;
mid_square = mid * mid;
min_square = min * min;
tmp = mid_square + min_square;
if(equal(mid,min) || equal(max, mid))
{
if(equal(mid, min))
{
if(mid == max)
puts("等边三角形。");
else if(equal(max_square, tmp))
puts("等腰直角三角形。");
else if(max_square < tmp)
puts("等腰锐角三角形。");
else
puts("等腰钝角三角形。");
}
else
{
if(equal(min, mid))
puts("等边三角形。");
else
puts("等腰锐角三角形。");
}
}
else if(equal(max_square, tmp))
puts("直角三角形。");
else if(max_square < tmp)
puts("锐角三角形。");
else
puts("钝角三角形。");
}
}
int main(void)
{
char cs, ch;
do
{
input();
sort();
judge();
if(input_err_flag)
{
input_err_flag = 0;
while((cs=getchar())!='
' && (cs=getchar())!=EOF);
printf("输入错误,a b c必须大于零,是否新输入(y/n):");
}
else if(judge_err_flag)
{
judge_err_flag = 0;
while((cs=getchar())!='
' && (cs=getchar())!=EOF);
printf("组不成三角形,是否重新输入(y/n):");
}
else
{
while((cs=getchar())!='
' && (cs=getchar())!=EOF);
printf("是否再输入一组数据(y/n):");
}
ch = getchar();
}
while(ch=='y' || ch=='Y' || ch=='
');
puts("Goodbye!");
return 0;
}
8. 如何用C语言编程序:输入三个数,判断是否构成三角形
需要准备的材料分别有:电脑、C语言编译器。
1、首先,打开C语言编译器,新建一个初始.cpp文件,例如:test.cpp。
9. 用C语言判断三角形
#include <iostream.h>
int main(void)
{
int a,b,c;
cout<<"请输入3个参数:"<<endl;
cin>>a>>b>>c;
if (!(a+b<=c || a+c<=b || b+c<=a))
{
if (a==b && a==c) cout<<"等边三角形"<<endl;
else if (a==b || a==c || b==c) cout<<"等腰三角形"<<endl;
else cout<<"不等边三角形"<<endl;
}
else cout<<"无法组成三角形"<<endl;
return(0);
}
10. c语言判断三角形
#include <stdio.h>
int main()
{
int a,b,c;
printf("输入三角形的三条边: ");
scanf("%d%d%d",&a,&b,&c);
if(a+b>c && a+c>b && b+c>a)
printf("三角形的周长为: %d\n",a+b+c);
else
printf("No\n");
return 0;
}示例运行结果:
输入三角形的三条边:
3
4
5
三角形的周长为:
12
输入三角形的三条边:
1
5
6
No