- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章解析C++编程中的选择结构和switch语句的用法由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
C++编写选择结构的程序 下面,通过两个实例来说明如何编写较为复杂的C++程序.
【例】编写程序,判断某一年是否为闰年.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
#include <iostream>
using
namespace
std;
int
main( )
{
int
year;
bool
leap;
cout<<
"please enter year:"
;
//输出提示
cin>>year;
//输入年份
if
(year%4==0)
//年份能被4整除
{
if
(year%100==0)
//年份能被4整除又能被100整除
{
if
(year%400==0)
//年份能被4整除又能被400整除
leap=
true
;
//闰年,令leap=true(真)
else
leap=
false
;
}
//非闰年,令leap=false(假)
else
//年份能被4整除但不能被100整除肯定是闰年
leap=
true
;
}
//是闰年,令leap=true
else
//年份不能被4整除肯定不是闰年
leap=
false
;
//若为非闰年,令leap=false
if
(leap)
cout<<year<<
" is "
;
//若leap为真,就输出年份和“是”
else
cout<<year<<
" is not "
;
//若leap为真,就输出年份和“不是”
cout<<
" a leap year."
<<endl;
//输出“闰年”
return
0;
}
|
运行情况如下:
1
2
3
4
|
① 2005↙
2005 is not a leap year.
② 1900↙
1900 is npt a leap year.
|
也可以将程序中第8~16行改写成以下的if语句:
1
2
3
4
5
6
7
8
|
if
(year%4!=0)
leap=
false
;
else
if
(year%100!=0)
leap=
true
;
else
if
(year%400!=0)
leap=
false
;
else
leap=
true
;
|
也可以用一个逻辑表达式包含所有的闰年条件,将上述if语句用下面的if语句代替: if((year%4 == 0 && year%100 !=0) || (year%400 == 0)) leap=true; else leap=false,
【例】运输公司对用户计算运费。路程(s)越远,每公里运费越低。标准如下:
1
2
3
4
5
6
|
s<250km 没有折扣
250≤s<500 2%折扣
500≤s<1000 5%折扣
1000≤s<2000 8%折扣
2000≤s<3000 10%折扣
3000≤s 15%折扣
|
设每公里每吨货物的基本运费为p(price的缩写),货物重为w(wright的缩写),距离为s,折扣为d(discount的缩写),则总运费f(freight的缩写)的计算公式为 。
1
|
f = p * w * s * (1 - d)
|
据此写出程序如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
#include <iostream>
using
namespace
std;
int
main( )
{
int
c,s;
float
p,w,d,f;
cout<<
"please enter p,w,s:"
;
cin>>p>>w>>s;
if
(s>=3000)
c=12;
else
c=s/250;
switch
(c)
{
case
0:d=0;
break
;
case
1:d=2;
break
;
case
2:
case
3:d=5;
break
;
case
4:
case
5:
case
6:
case
7:d=8;
break
;
case
8:
case
9:
case
10:
case
11:d=10;
break
;
case
12:d=15;
break
;
}
f=p*w*s*(1-d/100.0);
cout<<
"freight="
<<f<<endl;
return
0;
}
|
运行情况如下:
1
2
|
please enter p,w,s:100 20 300↙
freight=588000
|
。
C++ switch语句(多选分支结构) switch语句是多分支选择语句,用来实现多分支选择结构。它的一般形式如下:
1
2
3
4
5
6
7
8
|
switch(表达式)
{
case 常量表达式1:语句1
case 常量表达式2:语句2
...
case 常量表达式n:语句n
default:语句n+1
}
|
例如,要求按照考试成绩的等级打印出百分制分数段,可以用switch语句实现:
1
2
3
4
5
6
7
8
|
switch
(grade)
{
case
'A'
: cout<<
"85~100\n"
;
case
'B'
: cout<<
"70~84\n"
;
case
'C'
: cout<<
"60~69\n"
;
case
'D'
: cout<<
"<60\n"
;
default
: cout<<
"error\n"
;
}
|
说明: 1) switch后面括号内的“表达式”,允许为任何类型.
2) 当switch表达式的值与某一个case子句中的常量表达式的值相匹配时,就执行此case子句中的内嵌语句,若所有的case子句中的常量表达式的值都不能与switch表达式的值匹配,就执行default子句的内嵌语句.
3) 每一个case表达式的值必须互不相同,否则就会出现互相矛盾的现象(对表达式的同一个值,有两种或多种执行方案).
4) 各个case和default的出现次序不影响执行结果。例如,可以先出现“default:…”,再出现“case 'D':…”,然后是“case 'A':…”.
5) 执行完一个case子句后,流程控制转移到下一个case子句继续执行。“case常量表达式”只是起语句标号作用,并不是在该处进行条件判断。在执行switch语句时,根据switch表达式的值找到与之匹配的case子句,就从此case子句开始执行下去,不再进行判断。例如,上面的例子中,若grade的值等于'A',则将连续输出:
1
2
3
4
5
|
85~100
70~84
60~69
<60
error
|
因此,应该在执行一个case子句后,使流程跳出switch结构,即终止switch语句的执行。可以用一个break语句来达到此目的。将上面的switch结构改写如下:
1
2
3
4
5
6
7
8
9
|
switch
(grade)
{
case
'A'
: cout<<
"85~100\n"
;
break
;
case
'B'
: cout<<
"70~84\n"
;
break
;
case
'C'
: cout<<
"60~69\n"
;
break
;
case
'D'
: cout<<
"<60\n"
;
break
;
default
: cout<<
"error\n"
;
break
;
}
|
最后一个子句(default)可以不加break语句。如果grade的值为'B',则只输出“70~84”。 。
在case子句中虽然包含一个以上执行语句,但可以不必用花括号括起来,会自动顺序执行本case子句中所有的执行语句.
6) 多个case可以共用一组执行语句,如 。
1
2
3
4
|
case 'A':
case 'B':
case 'C': cout<<">60\n";break;
...
|
当grade的值为'A'?'B'或'C'时都执行同一组语句.
最后此篇关于解析C++编程中的选择结构和switch语句的用法的文章就讲到这里了,如果你想了解更多关于解析C++编程中的选择结构和switch语句的用法的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我目前正在尝试基于哈希表构建字典。逻辑是:有一个名为 HashTable 的结构,其中包含以下内容: HashFunc HashFunc; PrintFunc PrintEntry; CompareF
如果我有一个指向结构/对象的指针,并且该结构/对象包含另外两个指向其他对象的指针,并且我想删除“包含这两个指针的对象而不破坏它所持有的指针”——我该怎么做这样做吗? 指向对象 A 的指针(包含指向对象
像这样的代码 package main import "fmt" type Hello struct { ID int Raw string } type World []*Hell
我有一个采用以下格式的 CSV: Module, Topic, Sub-topic 它需要能够导入到具有以下格式的 MySQL 数据库中: CREATE TABLE `modules` ( `id
通常我使用类似的东西 copy((uint8_t*)&POD, (uint8_t*)(&POD + 1 ), back_inserter(rawData)); copy((uint8_t*)&PODV
错误 : 联合只能在具有兼容列类型的表上执行。 结构(层:字符串,skyward_number:字符串,skyward_points:字符串)<> 结构(skyward_number:字符串,层:字符
我有一个指向结构的指针数组,我正在尝试使用它们进行 while 循环。我对如何准确初始化它并不完全有信心,但我一直这样做: Entry *newEntry = malloc(sizeof(Entry)
我正在学习 C,我的问题可能很愚蠢,但我很困惑。在这样的函数中: int afunction(somevariables) { if (someconditions)
我现在正在做一项编程作业,我并没有真正完全掌握链接,因为我们还没有涉及它。但是我觉得我需要它来做我想做的事情,因为数组还不够 我创建了一个结构,如下 struct node { float coef;
给定以下代码片段: #include #include #define MAX_SIZE 15 typedef struct{ int touchdowns; int intercepti
struct contact list[3]; int checknullarray() { for(int x=0;x<10;x++) { if(strlen(con
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: Empty “for” loop in Facebook ajax what does AJAX call
我刚刚在反射器中浏览了一个文件,并在结构构造函数中看到了这个: this = new Binder.SyntaxNodeOrToken(); 我以前从未见过该术语。有人能解释一下这个赋值在 C# 中的
我经常使用字符串常量,例如: DICT_KEY1 = 'DICT_KEY1' DICT_KEY2 = 'DICT_KEY2' ... 很多时候我不介意实际的文字是什么,只要它们是独一无二的并且对人类读
我是 C 的新手,我不明白为什么下面的代码不起作用: typedef struct{ uint8_t a; uint8_t* b; } test_struct; test_struct
您能否制作一个行为类似于内置类之一的结构,您可以在其中直接分配值而无需调用属性? 前任: RoundedDouble count; count = 5; 而不是使用 RoundedDouble cou
这是我的代码: #include typedef struct { const char *description; float value; int age; } swag
在创建嵌套列表时,我认为 R 具有对列表元素有用的命名结构。我有一个列表列表,并希望应用包含在任何列表中的每个向量的函数。 lapply这样做但随后剥离了列表的命名结构。我该怎么办 lapply嵌套列
我正在做一个用于学习目的的个人组织者,我从来没有使用过 XML,所以我不确定我的解决方案是否是最好的。这是我附带的 XML 文件的基本结构:
我是新来的 nosql概念,所以当我开始学习时 PouchDB ,我找到了这个转换表。我的困惑是,如何PouchDB如果可以说我有多个表,是否意味着我需要创建多个数据库?因为根据我在 pouchdb
我是一名优秀的程序员,十分优秀!