- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章C++条件语句和条件运算符的使用方法讲解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
if语句的3种形式 。
1) if(表达式) 语句.
例如:
1
|
if
(x>y) cout<<x<<endl;
|
这种if语句的执行过程见下图.
2) if(表达式) 语句1 else 语句2 。
例如:
1
2
|
if
(x>y) cout<<x;
else
cout<<y;
|
见图.
3) 。
1
2
3
4
5
6
|
if(表达式1) 语句1
else if(表达式2) 语句2
else if(表达式3) 语句3
…
else if(表达式m) 语句m
else 语句n
|
例如:
1
2
3
4
5
|
if
(number>500) cost=0.15;
else
if
(number>300) cost=0.10;
else
if
(number>100) cost=0.075;
else
if
(number>50) cost=0.05;
else
cost=0;
|
流程图见图.
说明: 从图3.5和图3.6可以看到: 3种形式的if语句都是由一个入口进来,经过对“表达式”的判断,分别执行相应的语句,最后归到一个共同的出口。这种形式的程序结构称为选择结构。在C++中if语句是实现选择结构主要的语句。 3种形式的if语句中在if后面都有一个用括号括起来的表达式,它是程序编写者要求程序判断的“条件”,一般是逻辑表达式或关系表达式。 第2、第3种形式的if语句中,在每个else前面有一分号,整个语句结束处有一分号。 在if和else后面可以只含一个内嵌的操作语句(如上例),也可以有多个操作语句,此时用花括号“{}”将几个语句括起来成为一个复合语句.
【例】求三角形的面积.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
#include <iostream>
#include <cmath> //使用数学函数时要包含头文件cmath
#include <iomanip> //使用I/O流控制符要包含头文件iomanip
using
namespace
std;
int
main( )
{
double
a,b,c;
cout<<
"please enter a,b,c:"
;
cin>>a>>b>>c;
if
(a+b>c && b+c>a && c+a>b)
{
//复合语句开始
double
s,area;
//在复合语句内定义变量
s=(a+b+c)/2;
area=
sqrt
(s*(s-a)*(s-b)*(s-c));
cout<<setiosflags(ios::fixed)<<setprecision(4);
//指定输出的数包含4位小数
cout<<
"area="
<<area<<endl;
//在复合语句内输出局部变量的值
}
//复合语句结束
else
cout<<
"it is not a trilateral!"
<<endl;
return
0;
}
|
运行情况如下:
1
2
|
please enter a, b, c:2.45 3.67 4.89↙
area=4.3565
|
变量s和area只在复合语句内用得到,因此在复合语句内定义,它的作用范围为从定义变量开始到复合语句结束。如果在复合语句外使用s和area,则会在编译时出错,系统认为这两个变量未经定义。将某些变量局限在某一范围内,与外界隔离,可以避免在其他地方被误调用。 if语句的嵌套 。
在if语句中又包含一个或多个if语句称为if语句的嵌套。一般形式如下:
1
2
3
4
5
6
|
if( )
if( )语句1
else 语句2
else
if( )语句3
else 语句4
|
应当注意if与else的配对关系。else总是与它上面最近的、且未配对的if配对。假如写成:
1
2
3
4
5
|
if( )
if( )语句1
else
if( )语句2
else 语句3
|
编程序者把第一个else写在与第一个if(外层if)同一列上,希望else与第一个if对应,但实际上else是与第二个if配对,因为它们相距最近,而且第二个if并未与任何else配对。为了避免误用,最好使每一层内嵌的if语句都包含else子句(如本节开头列出的形式),这样if的数目和else的数目相同,从内层到外层一一对应,不致出错.
如果if与else的数目不一样,为实现程序设计者的企图,可以加花括号来确定配对关系。例如:
1
2
3
4
5
|
if
( )
{
if
( ) 语句1
}
//这个语句是上一行if语句的内嵌if
else
语句2
//本行与第一个if配对
|
这时{ }限定了内嵌if语句的范围,{ }外的else不会与{ }内的if配对。关系清楚,不易出错.
C++条件运算符(? :) 若在if语句中,当被判别的表达式的值为“真”或“假”时,都执行一个赋值语句且给同一个变量赋值时,可以用简单的条件运算符来处理。例如,若有以下if语句:
1
2
|
if
(a>b) max=a;
else
max=b;
|
可以用条件运算符(? :)来处理:
1
|
max=(a>b)?a:b;
|
其中“(a>b)?a:b”是一个“条件表达式”。它是这样执行的:如果(a>b)条件为真,则条件表达式的值就取“?”后面的值,即条件表达式的值为a,否则条件表达式的值为“:”后面的值,即b.
条件运算符要求有3个操作对象,称三目(元)运算符,它是C++中惟一的一个三目运算符。条件表达式的一般形式为:
1
|
表达式1 ? 表达式2 : 表达式3;
|
条件运算符的执行顺序是:先求解表达式1,若为非0(真)则求解表达式2,此时表达式2的值就作为整个条件表达式的值。若表达式1的值为0(假),则求解表达式3,表达式3的值就是整个条件表达式的值。“max=(a>b)?a:b” 的执行结果是将条件表达式的值赋给max。也就是将a和b二者中的大者赋给max。条件运算符优先于赋值运算符,因此上面赋值表达式的求解过程是先求解条件表达式,再将它的值赋给max.
条件表达式中,表达式1的类型可以与表达式2和表达式3的类型不同。如 。
1
|
x ? 'a': 'b';
|
如果已定义x为整型变量,若x=0,则条件表达式的值为字符'b'的ASCII码。表达式2和表达式3的类型也可以不同,此时条件表达式的值的类型为二者中较高的类型。如有条件表达式x>y?1:1.5,如果x≤y,则条件表达式的值为1.5,若x>y,值应为1,由于C++把1.5按双精度数处理,双精度的类型比整型高,因此,将1转换成双精度数,以此作为表达式的值.
【例】输入一个字符,判别它是否为大写字母,如果是,将它转换成小写字母;如果不是,不转换。然后输出最后得到的字符.
1
2
3
4
5
6
7
8
9
10
|
#include <iostream>
using
namespace
std;
int
main( )
{
char
ch;
cin>>ch;
ch=(ch>=
'A'
&& ch<=
'Z'
)?(ch+32):ch;
//判别ch是否大写字母,是则转换
cout<<ch<<endl;
return
0;
}
|
。
最后此篇关于C++条件语句和条件运算符的使用方法讲解的文章就讲到这里了,如果你想了解更多关于C++条件语句和条件运算符的使用方法讲解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我正在努力处理查询的 WHERE 部分。查询本身包含一个基于两个表中都存在的 ID 的 LEFT JOIN。但是,我要求 where 语句仅返回其中一列中存在的最大单个结果。目前我返回连接中的所有值,
我有这个代码来改变文件系统的大小。问题是,即使满足 if 条件,它也不会进入 if 条件,而我根本没有检查 if 条件。它直接进入 else 条件。 运行代码后的结果 post-install-ray
假设我有一个包含 2 列的 Excel 表格:单元格 A1 到 A10 中的日期和 B1 到 B10 中的值。 我想对五月日期的所有值求和。我有3种可能性: {=SUM((MONTH(A1:A10)=
伪代码: SELECT * FROM 'table' WHERE ('date' row.date 或 ,我们在Stack Overflow上找到一个类似的问题: https://stackove
我有下面这行代码做一个简单的查询 if ($this->fulfilled) $criteria->addCondition('fulfilled ' . (($this->fulfilled
如果在数据库中找到用户输入的键,我将尝试显示“表”中的数据。目前我已将其设置为让数据库检查 key 是否存在,如下所示: //Select all from table if a key entry
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 5 年前。 Improve th
在MYSQL中可以吗 一共有三个表 任务(task_id、task_status、...) tasks_assigned_to(ta_id、task_id、user_id) task_suggeste
我想先根据用户的状态然后根据用户名来排序我的 sql 请求。该状态由 user_type 列设置: 1=活跃,2=不活跃,3=创始人。 我会使用此请求来执行此操作,但它不起作用,因为我想在“活跃”成员
下面两个函数中最专业的代码风格是什么? 如果函数变得更复杂和更大,例如有 20 个检查怎么办? 注意:每次检查后我都需要做一些事情,所以我不能将所有内容连接到一个 if 语句中,例如: if (veh
我在 C# 项目中使用 EntityFramework 6.1.3 和 SQL Server。我有两个查询,基本上应该执行相同的操作。 1. Exams.GroupBy(x=>x.SubjectID)
我试图在 case when 语句中放入两个条件,但我在 postgresql 中遇到语法错误 case when condition 1 and condition 2 then X else Y
我正在构建一个连接多个表的查询,一个表 prodRecipe 将包含某些行的数据,但不是全部,但是 tmp_inv1 将包含所有行的计数信息。问题是,tmp_inv1.count 取决于某个项目是否在
我有一个涉及 couples of rows which have a less-than-2-hours time-difference 的查询(~0.08333 天): SELECT mt1.*,
我有一个包含许多这样的 OR 条件的代码(工作正常)来检查其中一个值是否为空,然后我们抛出一条错误消息(所有这些都必须填写) } elsif ( !$params{'account'}
我有一个名为 spGetOrders 的存储过程,它接受一些参数:@startdate 和 @enddate。这将查询“订单”表。表中的一列称为“ClosedDate”。如果订单尚未关闭,则此列将保留
在代码中,注释部分是我需要解决的问题...有没有办法在 LINQ 中编写这样的查询?我需要这个,因为我需要根据状态进行排序。 var result = ( from contact in d
我正在尝试创建一个允许省略参数的存储过程,但如果提供了参数,则进行 AND 操作: CREATE PROCEDURE MyProcedure @LastName Varchar(30)
我正在寻找一种方法来过滤我的主机文件中的新 IP 地址。我创建了一个脚本,每次我用来自矩阵企业管理器的数据调用它时都会更新我的主机文件。它工作正常。但是我必须找到一个解决方案,只允许更新 10.XX.
所以我正在做一种 slider ,当它完全向下时隐藏向下按钮,反之亦然,当向上按钮隐藏时,我遇到了问题。 var amount = $('slide').attr('number'); $('span
我是一名优秀的程序员,十分优秀!