C++第8周项目4要不要加油

本文介绍了一个简单的程序设计案例,用于赛车上的计算机监视系统。该程序能够在油量偏低时警示车手,并在油箱接近满载时告知车手不必进站加油。通过对比不同实现方式,展示了正确的逻辑结构对于程序正确性的关键作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759

【项目4:要不要加油?】设计一个程序,用于赛车上的计算机监视系统。该程序在赛车油量偏低时(少于1/4),警示车手应该注意;在油箱接近满载(不低于3/4)时要告诉车手绕过维修站。在其他情况下,不提示任何信息,以免车手分心。
  理一下思路,要给车手提示的信息来自于:

如果油量计(fuel_reading)不足3/4(即0.75),那么:
    如果油量低于满箱的1/4,就发出低油量警示;
否则(也就是说,油量计高于满箱的3/4)
    输出一条信息,告诉车手不要停车
  请设计出这个程序来,输入油量刻度(0-1之内的数,如0.21),提示相应信息,如果需要的话。

  参考解答:

//解法1
#include <iostream>
using namespace std;
int main( )
{
    double fuel_reading;
 
    cout << "输入油量表读数(0-1): ";
    cin >> fuel_reading;
 
    //下面加上花括号使if-else能够正确匹配
    if (fuel_reading < 0.75)
    {
        if (fuel_reading < 0.25)
            cout << "油量低,注意!\n";
    }
    else
    {
        cout << "高油量,不必停!\n";
    }
    return 0;
}

  下面的一种解法会得到错误的结果:

//解法2
#include <iostream>
using namespace std;
int main( )
{
    double fuel_reading;
 
    cout << "输入油量表读数(0-1): ";
    cin >> fuel_reading;
 
    if (fuel_reading < 0.75)
        if (fuel_reading < 0.25)
            cout << "油量低,注意!\n";
    else 
        cout << "高油量,不必停!\n";
    return 0;
}
  错误原因:第14行的 else 将会与最近的 if 配对,从而只要 fuel_reading >= 0.25 ,就会输出 " 高油量,不必停 !\n" ,这是错误的。由此可以看出解法 1 中第13行至第16行中加上花括号的必要。

 

  有同学给出了下面的解答,得到了正确的结果

//解法3
#include <iostream>
using namespace std;
int main( )
{
    double fuel_reading;
    cout << "输入油量表读数(0-1): ";
    cin >> fuel_reading;
    if (fuel_reading > 0.75)
        cout << "高油量,不必停!\n";
    if (fuel_reading < 0.25)
        cout << "油量低,注意!\n";
    return 0;
}

==================== 迂者 贺利坚 CSDN博客专栏=================

|==  IT学子成长指导专栏  专栏文章分类目录(不定期更新)    ==|

|== C++ 课堂在线专栏   贺利坚课程教学链接(分课程年级)   ==|

======== 为IT菜鸟起飞铺跑道,和学生一起享受快乐和激情的大学 =======



内容概要:本文详细记录了使用gmssl工具进行证书签发的全过程。首先创建了一个根证书(root.crt),包括生成私钥(root.key)、配置文件(root.cnf)以及设置扩展属性。接着基于该根证书签发了服务器证书(server.crt)和客户端证书(client.crt),并分别为它们生成了相应的私钥(server.key 和 client.key)。最后将服务器和客户端的公私钥对打包成PKCS#12格式文件(server.p12 和 client.p12)。整个过程涉及到了椭圆曲线加密算法SM2、哈希算法SM3,以及X.509标准中的一些重要概念如证书扩展、密钥用法等。 适合人群:对网络安全有兴趣的技术人员,尤其是那些希望深入了解SSL/TLS协议下证书机制的人士。 使用场景及目标:①理解根证书、服务器证书和客户端证书之间的关系及其作用;②掌握如何利用开源工具gmssl来创建符合国家标准的安全证书;③学习关于X.509 v3版本证书的具体结构与组成部分,包括版本号、序列号、签名算法、颁发者信息、有效期、主体信息、公钥信息、扩展属性等。 其他说明:本示例展示了在中国国家标准环境下(采用国密算法SM2和SM3)的手动证书签发流程,对于实际生产环境而言,通常会借助专业的证书颁发机构(CA)完成此类操作。此外,在创建证书请求时,可以通过配置文件或命令行参数指定具体的主题信息,以确保证书符合特定应用场景的需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

迂者-贺利坚

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值