第三章——控制流

一、语句与程序块

       分号是语句结束符,一对花括号把一组声明和语句括在一起构成一个复合语句(程序块)

二、if-else语句

           if(表达式)

                语句1

          else

                语句2

三、else-if语句

           if(表达式)

               语句

           else if(表达式)

               语句

           else if (表达式)

               语句

           else

                语句

 

四、switch语句

          switch语句是一种多路判定语句。

       switch语句改写统计数字、空白符、其他字符的程序如下:

#include <stdio.h>

int main(){
 int c, i, nwhite, nother, ndigit[10];

 nwhite = nother = 0;
 for (i = 0; i < 10; i++)
  ndigit[i] = 0;
 while ((c = getchar()) != EOF)
 {
  switch (c){
  case'0': case'1': case'2': case'3': case'4':
  case'5': case'6': case'7': case'8': case'9':
   ndigit[c - '0']++;//数字统计
   break;
  case' ': case'\n': case'\t':
   nwhite++;         //空白符
   break;
  default:
   nother++;         //其他字符
   break;
  }
 }
 printf("digits = ");
 for (i = 0; i < 10; i++)
  printf("%d", ndigit[i]);
 printf(",white space = %d,other = %d\n", nwhite, nother);
 return 0;

}

五、while循环与for循环

      这里使用了shell排序算法,先比较距离远的元素,这样可以快速减少大量的无序情况,从而减轻后续工作。为了能正常进行排序运算,我将shellsort改为int返回类型,并相应添加了main函数。

  #include <stdio.h>

int shellsort(int v[], int n)
{
 int gap, i, j, temp;

 for (gap = n / 2; gap > 0;gap/=2)
 for (i = gap; i < n;i++)
 for (j = i - gap; j >= 0 && v[j]>v[j + gap]; j -= gap)
 {
  temp = v[j];
  v[j] = v[j + gap];
  v[j + gap] = temp;
 }
 return *v;
}

int main(){
 int v[10] = { 3, 2, 6, 4, 7, 1, 8, 9, 5, 0 };
 shellsort(v, 10);
 for (int i = 0; i < 10; i++)
  printf("%d\t", v[i]);

 return 0;
}

六、do-while循环

#include <stdio.h>
#include <string.h>


void reverse(char s[])
{//倒置字符串s中的各个字符的位置
 int c, i, j;
 for (i = 0, j = strlen(s) - 1; i < j; i++, j--)
 {
  c = s[i];
  s[i] = s[j];
  s[j] = c;
 }
}

void itoa(int n, char s[])
{//将数字n转换为字符串并保存到s中
 int i, sign;
 if ((sign = n) < 0)//记录符号
  n = -n;              //使n成为正数
 i = 0;
 do{
  s[i++] = n % 10 + '0';
 } while ((n /= 10)>0);
 if (sign < 0)
  s[i++] = '-';
 s[i] = '\0';
 reverse(s);
 printf("%s", s);

}


int main(){
 int n = 12345;
 char s[10];
 itoa(n, s);

 return 0;
}

七、break语句与continue语句

#include <stdio.h>
#include <string.h> //为了调用strlen()

int trim(char s[])   //只删除反向遍历的第一个空格符、制表符或换行符
{
 int n;
 for (n = strlen(s) - 1; n >= 0;n--)
 if (s[n] != ' '&&s[n] != '\n'&&s[n] != '\t')
  break;
 s[n + 1] = '\0';
 return n;

}

int main(){
 //char s[10] = { '1', '3', '\n', '0', 's', 'q', ' ', 'd', 'a','v' };
 char s[10] = {'1','2','3'};
 printf("%d", trim(s));

 return 0;
}

八、goto语句与标号

       break语句是从最内层循环跳出到上一层循环,而goto语句是可以任意跳转


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值