您现在的位置:计算机技术学习网 > 技术中心 > 编程开发 > C >

C语言初学者入门讲座 第八讲 转移语句

来源:网络收集 责任编辑:栏目编辑 发表时间:2013-07-01 09:09 点击:
 程序中的语句通常总是按顺序方向, 或按语句功能所定义的方向执行的。如果需要改变程序的正常流向, 可以使用本小节介绍的转移语句。在C语言中提供了4种转移语句:

  goto,break, continue和return。

  其中的return语句只能出现在被调函数中, 用于返回主调函数,我们将在函数一章中具体介绍。 本小节介绍前三种转移语句。

  1.goto语句

  goto语句也称为无条件转移语句,其一般格式如下: goto 语句标号; 其中语句标号是按标识符规定书写的符号, 放在某一语句行的
前面,标号后加冒号(:)。语句标号起标识语句的作用,与goto 语句配合使用。

  如: label: i++;
    loop: while(x<7);

  C语言不限制程序中使用标号的次数,但各标号不得重名。goto语句的语义是改变程序流向, 转去执行语句标号所标识的语句。

  goto语句通常与条件语句配合使用。可用来实现条件转移, 构成循环,跳出循环体等功能。

  但是,在结构化程序设计中一般不主张使用goto语句, 以免造成程序流程的混乱,使理解和调试程序都产生困难。

  统计从键盘输入一行字符的个数。

#include"stdio.h"
void main(){
 int n=0;
 printf("input a string\n");
 loop: if(getchar()!='\n')
 {
  n++;
  goto loop;
 }
 printf("%d",n);
} int n=0;
printf("input a string\n");
loop: if(getchar()!='\n')
{
 n++;
 goto loop;
}
printf("%d",n);  

  本例用if语句和goto语句构成循环结构。当输入字符不为'\n'时即执行n++进行计数,然后转移至if语句循环执行。直至输入字符为'\n'才停止循环。

  break语句

  break语句只能用在switch 语句或循环语句中, 其作用是跳出switch语句或跳出本层循环,转去执行后面的程序。由于break语句的转移方向是明确的,所以不需要语句标号与之配合。break语句的一般形式为: break; 上面例题中分别在switch语句和for语句中使用了break 语句作为跳转。使用break语句可以使循环语句有多个出口,在一些场合下使编程更加灵活、方便。

  continue语句

  continue语句只能用在循环体中,其一般格式是:

continue;

  其语义是:结束本次循环,即不再执行循环体中continue 语句之后的语句,转入下一次循环条件的判断与执行。应注意的是, 本语句只结束本层本次的循环,并不跳出循环。

void main(){
 int n;
 for(n=7;n<=100;n++)
 {
  if (n%7!=0)
   continue;
  printf("%d ",n);
 }
}

  输出100以内能被7整除的数。

int n;
for(n=7;n<=100;n++)
{
 if (n%7!=0)
  continue;
 printf("%d ",n);
}

  本例中,对7~100的每一个数进行测试,如该数不能被7整除,即模运算不为0,则由continus语句转去下一次循环。只有模运算为0时,才能执行后面的printf语句,输出能被7整除的数。

#include"stdio.h"
void main(){
 char a,b;
 printf("input a string:\n");
 b=getchar();
 while((a=getchar())!='\n'){
  if(a==b){
   printf("same character\n");
   break;
  }b=a;
 }
}

  检查输入的一行中有无相邻两字符相同。

char a,b;
printf("input a string:\n");
b=getchar();
while((a=getchar())!='\n'){
 if(a==b){
  printf("same character\n");
  break;
 }b=a;
}

  本例程序中,把第一个读入的字符送入b。然后进入循环,把下一字符读入a,比较a,b是否相等,若相等则输出提示串并中止循环,若不相等则把a中的字符赋予b,输入下一次循环。

  输出100以内的素数。素数是只能被1 和本身整除的数。可用穷举法来判断一个数是否是素数。

void main(){
 int n,i;
 for(n=2;n<=100;n++){
  for(i=2;i<n;i++)
   if(n%i==0) break;
   if(i>=n) printf("\t%d",n);
  }
 } int n,i;
 for(n=2;n<=100;n++){
  for(i=2;i<n;i++)
   if(n%i==0) break;
   if(i>=n) printf("\t%d",n);
}

  本例程序中,第一层循环表示对1~100这100个数逐个判断是否是素数,共循环100次,在第二层循环中则对数n用2~n-1逐个去除,若某次除尽则跳出该层循环,说明不是素数。 如果在所有的数都是未除尽的情况下结束循环,则为素数,此时有i>=n, 故可经此判断后输出素数。然后转入下一次大循环。实际上,2以上的所有偶数均不是素数,因此可以使循环变量的步长值改为2,即每次增加2,此外只需对数n用2~n去除就可判断该数是否素数。这样将大大减少循环次数,减少程序运行时间。

#include"math.h"
void main(){
 int n,i,k;
    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1