CDMA2000无线网络规划.ppt
《CDMA2000无线网络规划.ppt》由会员分享,可在线阅读,更多相关《CDMA2000无线网络规划.ppt(66页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、6.1 概述在许多问题中需要用到循环控制。例如,要输入全校学生成绩;求若干个数之和;迭代求根等。几乎所有实用的程序都包含循环。循环结构是结构化程序设计的基本结构之一,它和顺序结构、选择结构共同作为各种复杂程序的基本构造单元。因此熟练掌握选择结构和循环结构的概念及使用是程序设计的最基本的要求。 (1) 用goto语句和if语句构成循环; (2) 用while语句; (3) 用do|while语句; (4) 用for语句。在下面各节中将分别作介绍。6.2 goto语句以及用goto语句构成循环goto语句为无条件转向语句,它的一般形式为 goto语句标号;语句标号用标识符表示,它的定名规则与变量名
2、相同,即由字母、数字和下划线组成,其第一个字符必须为字母或下划线。不能用整数来做标号。例如:goto label-1;是合法的,而goto 123;是不合法的。结构化程序设计方法主张限制使用goto语句,因为滥用goto语句将使程序流程无规律、可读性差。但也不是绝对禁止使用goto语句。一般来说,可以有两种用途:(1) 与if语句一起构成循环结构;(2) 从循环体中跳转到循环体外,但在c语言中可以用break语句和continue语句(见6.8节)跳出本层循环和结束本次循环。goto语句的使用机会已大大减少,只是需要从多层循环的内层循环跳到外层循环外时才用到goto语句。但是这种用法不符合结构
3、化原则,一般不宜采用,只有在不得已时(例如能大大提高效率)才使用。例6.1用if语句和goto语句构成循环,求n。 此问题的算法是比较简单的,可以直接写出程序: main( ) int i, sum=0;i=1;loop: if(i=100) sum=sum+i; i+; goto loop; printf(%d,sum); 100n=1运行结果如下:5050这里用的是“当型”循环结构,当满足“i=100” 时执行花括弧内的循环体。请读者自己画出流程图。6.3while语句while语句用来实现“当型”循环结构。其一般形式如下:while (表达式) 语句当表达式为非0值时,执行while语句
4、中的内嵌语句。其流程图见图6.1。其特点是:先判断表达式,后执行语句。图图6.1图图6.2例6.2求n。用传统流程图和NS结构流程图表示算法,见图6.2(a)和图6.2(b)。根据流程图写出程序:main() int i,sum=0; i=1; while (i100”,因此在循环体中应该有使i增值以最终导致i100的语句,今用“i+;”语句来达到此目的。如果无此语句,则i的值始终不改变,循环永不结束。6.4 do while语句do while语句的特点是先执行循环体,然后判断循环条件是否成立。其一般形式为do 循环体语句 while (表达式);它是这样执行的:先执行一次指定的循环体语句,
5、然后判别表达式,当表达式的值为非零(“真”) 时,返回重新执行循环体语句,如此反复,直到表达式的值等于0为止,此时循环结束。可以用图6.3表示其流程。请注意dowhile循环用NS流程图的表示形式(图6.3(b)。图6.3例6.3用dowhile语句求n。先画出流程图,见图6.4。图图6.46.4图图6.56.5100n=1程序如下:main() int i,sum=0; i=1; do sum=sum+i; i+; while(i=100); printf(%d,sum); 可以看到:对同一个问题可以用while语句处理,也可以用do-while语句处理。Do-while语句结构可以转换成w
6、hile结构。图6.3可以改画成图6.5形式,二者完全等价。而图6.5中线框部分就是一个while结构。可见,do-while结构是由一个语句加一个while结构构成的。若图6.1中表达式值为真,则图6.1也与图6.5等价(因为都要先执行一次语句)。在一般情况下,用while语句和用do-while语句处理同一问题时,若二者的循环体部分是一样的,它们的结果也一样。如例6.2和例6.3程序中的循环体是相同的,得到结果也相同。但是如果while后面的表达式一开始就为假(0值)时,两种循环的结果是不同的。例6.4while和do-while循环的比较。(1) main ( ) (2) main( )
7、 int sum=0,i; int sum=0,i; scanf(“%d”,&i); scanf(%d,&i); while (i=10) do sum=sum+i; sum=sum+i;i+; i+; while (i10时,二者结果就不同了。这是因为此时对while循环来说,一次也不执行循环体(表达式“i10时,二者结果就不同了。这是因为此时对while循环来说,一次也不执行循环体(表达式“i100”。因为“当i100时继续执行循环”和“直到i100结束循环”是对同一问题的两种表述方式。千万不要在图5|4(b)中写成“直到i100”。6.5 for 语 句C语言中的for语句使用最为灵活,
8、不仅可以用于循环次数已经确定的情况,而且可以用于循环次数不确定而只给出循环结束条件的情况,它完全可以代替while语句。 for语句的一般形式为for(表达式1;表达式2;表达式3) 语句 它的执行过程如下: (1) 先求解表达式1。 (2) 求解表达式2,若其值为真(值为非0),则执行for语句中指定的内嵌语句,然后执行下面第(3)步。若为假(值为0),则结束循环,转到第(5)步。 (3) 求解表达式3。 (4) 转回上面第(2)步骤继续执行。 (5) 循环结束,执行for语句下面的一个语句。 可以用图6.6来表示for语句的执行过程。for语句最简单的应用形式也就是最易理解的如下形式:图图
9、6.6for(循环变量赋初值;循环条件;循环变量增值) 语句 例如:for(i=1;i=100;i+) sum=sum+i;它的执行过程与图6.2完全一样。可以看到它相当于以下语句:i=1; while(i=100) sum=sum+i; i+; 显然,用for语句简单、方便。对于以上for语句的一般形式也可以改写为while循环的形式:表达式1;while(表达式2) 语句 表达式3; 说明:(1) for语句的一般形式中的“表达式1”可以省略,此时应在for语句之前给循环变量赋初值。注意省略表达式1时,其后的分号不能省略。如for(;i=100;i+) sum=sum+i;执行时,跳过“求
10、解表达式1”这一步,其他不变。(2) 如果表达式2省略,即不判断循环条件,循环无终止地进行下去。也就是认为表达式2始终为真。见图6.7。图6.7例如:for(i=1; ;i+) sum=sum+i;表达式1是一个赋值表达式,表达式2空缺。它相当于:i=1; while(1) sum=sum+1; i+;(3) 表达式3也可以省略,但此时程序设计者应另外设法保证循环能正常结束。如:(4)可以省略表达式1和表达式3,只有表达式2,即只给循环条件,如:for(;i=100;) while(i=100) sum=sum+i; 相当于 sum=sum+i; i+; i+;在这种情况下,完全等同于whil
11、e语句。可见for语句比while语句功能强,除了可以给出循环条件外,还可以赋初值,使循环变量自动增值等。(5)三个表达式都可省略,如:for(;) 语句相当于while(1)语句。即不设初值,不判断条件(认为表达式2为真值),循环变量不增值。无终止地执行循环体。(6) 表达式1可以是设置循环变量初值的赋值表达式,也可以是与循环变量无关的其他表达式。如:for (sum=0;i=100;i+) sum=sum+i;表达式3也可以是与循环控制无关的任意表达式。 表达式1和表达式3可以是一个简单的表达式,也可以是逗号表达式,即包含一个以上的简单表达式,中间用逗号间隔。如:for(sum=0,i=1
12、;i=100;i+) sum=sum+i;或for(i=0,j=100;i=j;i+,j-) k+=i*j;表达式1和表达式3都是逗号表达式,各包含两个赋值表达式,即同时设两个初值,使两个变量增值,执行情况见图6.8。在逗号表达式内按自左至右顺序求解,整个逗号表达式的值为其中最右边的表达式的值。如:for(i=1;i=100;i+,i+) sum=sum+i;相当于for(i=1;i=100;i=i+2) sum=sum+i;。图图6.9图图6.8(7) 表达式一般是关系表达式(如i=100)或逻辑表达式(如ab & xy),但也可以是数值表达式或字符表达式,只要其值为非零,就执行循环体。分析
13、下面两个例子: for(i=0;(c=getchar()!=n;i+=c);在表达式2中先从终端接收一个字符赋给c,然后判断此赋值表达式的值是否不等于n(换行符),如果不等于n,就执行循环体。此for语句的执行过程见图6.9,它的作用是不断输入字符,将它们的ascII码相加,直到输入一个“换行”符为止。注意:此for语句的循环体为空语句,把本来要在循环体内处理的内容放在表达式3中,作用是一样的。可见for语句功能强,可以在表达式中完成本来应在循环体内完成的操作。 for( ;(c=getchar()!=n;) printf(%c,c);只有表达式2,而无表达式1和表达式3。其作用是每读入一个字
14、符后立即输出该字符,直到输入一个“换行”为止。请注意,从终端键盘向计算机输入时,是在按Enter键以后才送到内存缓冲区中去的。运行情况:computer (输入)computer (输出)而不是ccoommppuutteerr即不是从终端敲入一个字符马上输出一个字符,而是按Enter键后数据送入内存缓冲区,然后每次从缓冲区读一个字符,再输出该字符。从上面介绍可以知道c语言中的for语句比其他语言(如baSIc,PascaL)中的fOR语句功能强得多。可以把循环体和一些与循环控制无关的操作也作为表达式1或表达式3出现,这样程序可以短小简洁。但过分地利用这一特点会使for语句显得杂乱,可读性降低,
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- CDMA2000 无线网络 规划
限制150内