博客
关于我
【C++ 程序】 判断是否构成三角形
阅读量:762 次
发布时间:2019-03-21

本文共 1369 字,大约阅读时间需要 4 分钟。

重新优化后的内容

程序代码

#include 
#include
#include
#include
#include
using namespace std;int main() { vector
vint1; string num1; int index = 0; try { vint1.clear(); cout << "Please input three integers: "; cin >> num1; istringstream is1(num1); double i; while (is1 >> i) { if (i - static_cast
(i) == 0) { // 判断是否为整数 vint1.push_back(i); } } if (vint1.size() != 3 || vint1[0] <= 0 || vint1[1] <= 0 || vint1[2] <= 0) { throw runtime_error("Illegal input!"); } } catch (runtime_error err) { cout << err.what() << "\nTry Again? Enter Y or N.\n"; char decision; cin >> decision; if (!cin || decision == 'n' || decision == 'N') { return -1; } else { cout << endl; goto begin; } } int length[3] = {vint1[0], vint1[1], vint1[2]}; sort(length, length + 3); if (length[0] + length[1] <= length[2]) { cout << "They don't make a triangle.\n"; } else { cout << "They make a triangle.\n"; } return 0;}

输出示例

程序要求用户输入三个整数。若输入符合要求且能够构成三角形,则输出"They make a triangle.",否则输出"They don't make a triangle."

分析

程序通过严格的输入验证确保用户输入符合预期:

  • 数量检查:严格检查输入的数量是否为三个
  • 类型检查:确保输入为整数
  • 正数检查:排除非正数
  • 非法输入处理:提示用户并重新输入

补充

程序可以通过以下方式强迫用户反复输入,直到正确:

while (1) {    char anything;    cin >> anything;    if (cin.fail()) {        cin.clear();        cin.ignore();        cout << "输入的不是整数!\n";    } else break;}

这个小程序会在用户输入非整数时提示并重新输入,直到输入正确为止。

转载地址:http://hcogz.baihongyu.com/

你可能感兴趣的文章
MySQL学习-排序与分组函数
查看>>
MySQL学习-连接查询
查看>>
Mysql学习总结(21)——MySQL数据库常见面试题
查看>>
Mysql学习总结(22)——Mysql数据库中制作千万级测试表
查看>>
Mysql学习总结(24)——MySQL多表查询合并结果和内连接查询
查看>>
Mysql学习总结(25)——MySQL外连接查询
查看>>
Mysql学习总结(26)——MySQL子查询
查看>>
Mysql学习总结(37)——Mysql Limit 分页查询优化
查看>>
Mysql学习总结(38)——21条MySql性能优化经验
查看>>
Mysql学习总结(45)——Mysql视图和事务
查看>>
Mysql学习总结(58)——深入理解Mysql的四种隔离级别
查看>>
Mysql客户端中文乱码问题解决
查看>>
Mysql工作笔记006---Mysql服务器磁盘爆满了_java.sql.SQLException: Error writing file ‘tmp/MYfXO41p‘
查看>>
Mysql建立中英文全文索引(mysql5.7以上)
查看>>
MySQL当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
查看>>
MySQL必知必会总结笔记
查看>>
MySQL快速入门——库的操作
查看>>
mysql快速复制一张表的内容,并添加新内容到另一张表中
查看>>
mysql怎么删除临时表里的数据_MySQL中关于临时表的一些基本使用方法
查看>>
mysql性能测试工具选择 mysql软件测试
查看>>