设计三角形问题的程序

输入三个整数a、b、c,分别作为三角形的三条边,现通过程序判断由三条边构成的三角形的类型为等边三角形、等腰三角形、一般三角形(特殊的还有直角三角形),以及不构成三角形。(等腰直角三角形,判断为等腰三角形)

现在要求输入三个整数a、b、c,必须满足以下条件:

条件1   1≤a≤100          条件4   a<b+ c

条件2   1≤b≤100          条件5   b<a+ c

条件3   1≤c≤100          条件6   c<a+ b

String triangle(int a,int b,int c)    返回字符型

程序要求:

1)先显示:“请输入三角形的三条边:”

2)只要有不满足条件1,2,3之一,就返回“边的值不在范围内!”

3)只要有不满足4,5,6之一,就返回“不构成三角形”

4)根据边的情况分别返回:“等边三角形”“等腰三角形”“直角三角形”“一般三角形”

源码:

#include<stdio.h>

int SameLengthNum(int a,int b,int c){

  int count = 0;

  if(a==b){   count++;  }

  if(a==c){   count++;  }

  if(b==c){   count++;  }

  return count;

}

char* Triangle(int a,int b,int c){

  char* ch;

  if(!(1<=a<=100) || !(1<=b<=100) || !(1<=c<=100)){   return ch="边的值不在范围内";  }

  if(!(a<(b+c)) || !(b<(a+c)) || !(c<(a+b))){   return ch="不构成三角形";  }

  switch(SameLengthNum( a, b, c)){

    case 0:{

      if((a*a+b*b)==(c*c) || (a*a+c*c)==(b*b) || (c*c+b*b)==(a*a))

        return ch="直角三角形";

      else

        return ch="一般三角形";

    }

    case 1: return ch="等腰三角形";

    case 3: return ch="等边三角形";

  }

}

void UseMethod(){

  int a,b,c;

  printf("请输入三角形的三条边(格式:a,b,c):\n");

  scanf("%d,%d,%d",&a,&b,&c);

  char* ch = Triangle(a,b,c);

  printf("测算结果:%s\n\n\n",ch);

}

void Menu(){

  bool flag = true;

  while(flag){

    printf("What can I do for you?\n\t1.测算三角形类型\n\t0.退出\n选择您所需要的功能:\n");

    int select = 0;

    scanf("%d",&select);

    switch(select){

      case 0: flag = false;printf("感谢您的使用,再见!\n");break;

      case 1: UseMethod();break;

    }

  }

}

void main(){  Menu(); }

-----------------------------------------3.19-----------------------------------------

修改后代码:

#include<stdio.h>

int SameLengthNum(int a,int b,int c){

  int count = 0;

  if(a==b){

    count++;

  }

  if(a==c){

    count++;

  }

  if(b==c){

    count++;

  }

  return count;

}

char* Triangle(int a,int b,int c){

  char* ch;

  if(!(1<=a&&a<=100) || !(1<=b&&b<=100) || !(1<=c&&c<=100)){

    return ch="边的值不在范围内";

  }

  if(!(a<(b+c)) || !(b<(a+c)) || !(c<(a+b))){

    return ch="不构成三角形";

  }

  switch(SameLengthNum( a, b, c)){

    case 0:{

      if((a*a+b*b)==(c*c) || (a*a+c*c)==(b*b) || (c*c+b*b)==(a*a))

        return ch="直角三角形";

      else

        return ch="一般三角形";

    }

    case 1: return ch="等腰三角形";

    case 3: return ch="等边三角形";

  }

}

void UseMethod(){

  float a,b,c;

  printf("请输入三角形的三条边(格式:a,b,c):\n");

  scanf("%f,%f,%f",&a,&b,&c);

  if((int)a!=a||(int)b!=b||(int)c!=c){

    printf("请输入整数。\n");

  }

  else{

    char* ch = Triangle(a,b,c);

    printf("测算结果:%s\n\n\n",ch);

  }

}

void Menu(){

  bool flag = true;

  while(flag){

    printf("What can I do for you?\n\t1.测算三角形类型\n\t0.退出\n选择您所需要的功能:\n");

    int select = 0;

    scanf("%d",&select);

    if(select!=0 && select!=1){

      printf("请输入0或1选择您所需要的功能。\n");

    }

    else{

      switch(select){

        case 0: {

          flag = false;

          printf("感谢您的使用,再见!\n");

          break;

        }

        case 1: UseMethod();break;

      }

    }

  }

}

void main(){

  Menu();

}

UT源码+105032014070的更多相关文章

  1. UT源码 005

    NextDate函数问题 NextDate函数说明一种复杂的关系,即输入变量之间逻辑关系的复杂性 NextDate函数包含三个变量month.day和year,函数的输出为输入日期后一天的日期. 要求 ...

  2. UT源码105032014093

    需求描述: 设计佣金问题的程序 commission方法是用来计算销售佣金的需求,手机配件的销售商,手机配件有耳机(headphone).手机壳(Mobile phone shell).手机贴膜(Ce ...

  3. UT源码 065

    NextDate函数问题 NextDate函数说明一种复杂的关系,即输入变量之间逻辑关系的复杂性 NextDate函数包含三个变量month.day和year,函数的输出为输入日期后一天的日期. 要求 ...

  4. UT源码105032014098

    (2)NextDate函数问题 NextDate函数说明一种复杂的关系,即输入变量之间逻辑关系的复杂性 NextDate函数包含三个变量month.day和year,函数的输出为输入日期后一天的日期. ...

  5. UT源码-124

    (1)设计三角形问题的程序 输入三个整数a.b.c,分别作为三角形的三条边,现通过程序判断由三条边构成的三角形的类型为等边三角形.等腰三角形.一般三角形(特殊的还有直角三角形),以及不构成三角形.(等 ...

  6. UT源码 105032014098

    package exam1; import java.util.Scanner; public class test01 { static String nextDate(int year,int m ...

  7. UT源码_105032014033

    需求描述: 设计佣金问题的程序 commission方法是用来计算销售佣金的需求,手机配件的销售商,手机配件有耳机(headphone).手机壳(Mobile phone shell).手机贴膜(Ce ...

  8. UT源码+019

    设计三角形问题的程序 输入三个整数a.b.c,分别作为三角形的三条边,现通过程序判断由三条边构成的三角形的类型为等边三角形.等腰三角形.一般三角形(特殊的还有直角三角形),以及不构成三角形.(等腰直角 ...

  9. UT源码162

    (3)设计佣金问题的程序 commission方法是用来计算销售佣金的需求,手机配件的销售商,手机配件有耳机(headphone).手机壳(Mobile phone shell).手机贴膜(Cellp ...

随机推荐

  1. 前端基础(JavaScript)

    JavaScript概述 JavaScript的历史 1992年Nombas开发出C-minus-minus(C--)的嵌入式脚本语言(最初绑定在CEnvi软件中).后将其改名ScriptEase.( ...

  2. Linux系统——公网定制化yum仓库部署

    1)搭建公网源yum仓库 安装wget aliyun源 # wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel ...

  3. Git 系列——第一步安装 Git

    之前也没有用过什么版本控制的工具,唯一用过的就是 SVN 了,不过也只是简单的使用而已,比如写好代码就签入,没了?是的,没了. 于是接触到了 Git 这个分布式版本控制软件,接下来就让我们好好学习,天 ...

  4. Learning to Rank之Ranking SVM 简介

    排序一直是信息检索的核心问题之一,Learning to Rank(简称LTR)用机器学习的思想来解决排序问题(关于Learning to Rank的简介请见我的博文Learning to Rank简 ...

  5. springcloud21---Config-bus实现配置自动刷新

    Pivotal(毕威拓)有VMware和EMC成立的. RabbitMQ是由ERlang(爱立信开发的,面向并发的编程语言),安装RabbitMQ先要安装ERlang. package com.itm ...

  6. sqlite的事务和锁,很透彻的讲解 【转】

    原文:sqlite的事务和锁 http://3y.uu456.com/bp-877d38906bec097sf46se240-1.html 事务 事务定义了一组SQL命令的边界,这组命令或者作为一个整 ...

  7. ubuntu14.04 安装apache+mysql+php

    1.安装apache sudo apt-get update sudo apt-get install apache2 这时http://你机器的ip,就可以访问了. 2.安装mysql sudo a ...

  8. zoj3696Alien's Organ (二项分布,泊松分布求近似值)

    /*二项分布即重复n次的伯努利试验,每次发生的概率一样,假设成功的概率是p,那么失败的概率就是1-p: 二项分布的概率公式:试验中发生K次的概率是 P(ξ=K)= C(n,k) * p^k * (1- ...

  9. [one day one question] safari缓存太厉害

    问题描述: safari缓存太厉害,这怎么破? 解决方案: window.onpageshow = function(event) { if (event.persisted) { window.lo ...

  10. SQL学习笔记四之MySQL数据操作

    阅读目录 一 介绍 二 插入数据INSERT 三 更新数据UPDATE 四 删除数据DELETE 五 查询数据SELECT 六 权限管理 一 介绍 MySQL数据操作: DML =========== ...