C语言 回滚技术 switch case

Python015

C语言 回滚技术 switch case,第1张

switch-case语句用法

2007-12-25 08:11

if语句处理两个分支,处理多个分支时需使用if-else-if结构,但如果分支较多,则嵌套的if语句层就越多,程序不但庞大而且理解也比较困难.因此,C语言又提供了一个专门用于处理多分支结构的条件选择语句,称为switch语句,又称开关语句.使用switch语句直接处理多个分支(当然包括两个分支).其一般形式为:

引用

--------------------------------------------------------------------------------

switch(表达式)

{

case 常量表达式1:

语句1

break

case 常量表达式2:

语句2

break

……

case 常量表达式n:

语句n

break

default:

语句n+1

break

}

--------------------------------------------------------------------------------

switch语句的执行流程是:首先计算switch后面圆括号中表达式的值,然后用此值依次与各个case的常量表达式比较,若圆括号中表达式的值与某个case后面的常量表达式的值相等,就执行此case后面的语句,执行后遇break语句就退出switch语句若圆括号中表达式的值与所有case后面的常量表达式都不等,则执行default后面的语句n+1,然后退出switch语句,程序流程转向开关语句的下一个语句.如下程序,可以根据输入的考试成绩的等级,输出百分制分数段:

引用

--------------------------------------------------------------------------------

switch(grade)

{

case 'A': /*注意,这里是冒号:并不是分号*/

printf("85-100\n")

break/*每一个case语句后都要跟一个break用来退出switch语句*/

case 'B': /*每一个case后的常量表达式必须是不同的值以保证分支的唯一性*/

printf("70-84\n")

break

case 'C':

printf("60-69\n")

break

case 'D':

printf("<60\n")

break

default:

printf("error!\n")

}

--------------------------------------------------------------------------------

(2) 如果在case后面包含多条执行语句时,也不需要像if语句那样加大括号,进入某个case后,会自动顺序执行本case后面的所有执行语句.如:

引用

--------------------------------------------------------------------------------

{

case 'A':

if(grade<=100)

printf("85-100\n")

else

printf("error\n")

break

……

--------------------------------------------------------------------------------

(3) default总是放在最后,这时default后不需要break语句.并且,default部分也不是必须的,如果没有这一部分,当switch后面圆括号中表达式的值与所有case后面的常量表达式的值都不相等时,则不执行任何一个分支直接退出switch语句.此时,switch语句相当于一个空语句.例如,将上面例子中switch语句中的default部分去掉,则当输入的字符不是"A","B","C"或"D"时,此switch语句中的任何一条语句也不被执行.

(4) 在switch-case语句中,多个case可以共用一条执行语句,如:

引用

--------------------------------------------------------------------------------

……

case 'A':

case 'B':

case 'c':

printf(">60\n")

break

……

--------------------------------------------------------------------------------

在A,B,C3种情况下,均执行相同的语句,即输出">60".

(5) 最开始那个例子中,如果把每个case后的break删除掉,则当greak='A'时,程序从printf("85-100\n")开始执行,输出结果为:

引用

--------------------------------------------------------------------------------

85-100

70-84

60-69

<60

error

--------------------------------------------------------------------------------

这是因为case后面的常量表达式实际上只起语句标号作用,而不起条件判断作用,即"只是开始执行处的入口标号".因此,一旦与switch后面圆括号中表达式的值匹配,就从此标号处开始执行,而且执行完一个case后面的语句后,若没遇到break语句,就自动进入下一个case继续执行,而不在判断是否与之匹配,直到遇到break语句才停止执行,退出break语句.因此,若想执行一个case分之后立即跳出switch语句,就必须在此分支的最后添加一个break语句.

引用

--------------------------------------------------------------------------------

main() /*完成两个数简单的四则运算*/

{

float a,b

char c1

printf("Please enter a,b and op:")

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

switch(c1)

{

case '+':

printf("%f+%f=%f\n",a,b,a+b)

break

case '-':

printf("%f-%f=%f\n",a,b,a-b)

break

case '*':

printf("%f*%f=%f\n",a,b,a*b)

break

case '/':

if(b!=0.0) /*分母不能等于0*/

printf("%f/%f=%f\n",a,b,a/b)

else

printf("error!\n")

break

default:

printf("error!\n")

break

}

}

楼主你好。

ROLLOEVER_INCREMENT是指回滚式地增加,这是一个宏。

#ifndef

ROLLOVER_INCREMENT

#endif

的意思是如果没有定义ROLLOVER_INCREMENT这个宏,就按如下定义这个宏:

#define

ROLLOVER_INCREMENT(a,

upperbound)

(((((a)+1)

>=

(upperbound))

?

0

:

(a)+1))

如果a+1大于等于上界,那么就返回0,否则返回a+1.

//遍历所有空格子。 for( int a = 0a <9a++ )//行。 { for( int b = 0b <9b++ )//列。 { if()//a行b列是0。 { //从1-9,找到可填入的数字。 for( int c = 1c <= 9c++ ) { bool isOk = truefor( int d = 0d <9d++ ) { if()//如果a行d列是c。 { isOk = falsebreak} else if()//如果d行b列是c。 { isOk = falsebreak} } if( isOk )//横纵都没有冲突。 { //判断3*3的9个格子里有没有冲突。 for( int d = d <d++ )//d的初始值 = a除以3取整。 { for( int e = e <e++ )//e的初始值 = b除以3取整。 { if()//如果d行e列是c。 { isOk = falsebreak} } if( !isOk ) { break} } } if( isOk )//该数字可以填进空格子。 ( //记录该数字。注意,要同时记录该格子的a和b,以便回滚。 ) else if( c == 9 )//没有任何可以填入的数字,这说明前边就有错的地方了。 { //回滚。即,将a、b改为前边格子的行、列索引,并将c设置为其填入的数字加1.当然,如果前边一个数字是9,那就再回滚一个。 } } } } }