博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
实验5-1 while循环结构
阅读量:4144 次
发布时间:2019-05-25

本文共 1748 字,大约阅读时间需要 5 分钟。

实验目的:

1.熟悉while循环结构

2.使用while循环结构

实验步骤:

1.if选择结构与while循环结构

1.1下面两个流程图有何区别与联系。

1)

2)

2.2分析下面的代码段。

1)int i = 2, sum = 1;

       if(i <= 5)

       {

              sum = sum + i;

              ++i;

       }

       printf("%d,%d\n", i, sum);

2)int i = 2, sum = 1;

       while(i <= 5)

       {

              sum = sum + i;

              ++i;

       }

       printf("%d,%d\n", i, sum);

2.3分析下面的代码段。

1)char ch = 'a';

       while(ch <= 'c')

       {

              putchar(ch);

              ++ch;

       }

       putchar(ch);

2)char ch = 'a';

       if(ch <= 'c')

       {

              putchar(ch);

              ++ch;

       }

       if(ch <= 'c')

       {

              putchar(ch);

              ++ch;

       }

       if(ch <= 'c')

       {

              putchar(ch);

              ++ch;

       }

       if(ch <= 'c')

       {

              putchar(ch);

              ++ch;

       }

       if(ch <= 'c')

       {

              putchar(ch);

              ++ch;

       }

       putchar(ch);

有人认为while循环结构可以用n个if选择结构代替,你觉得呢?

提示:除了简洁性,还应考虑表达式各种取值的情况。

3.计算1+2+3+4+5有如下三种算法,请分析比较。

1)

       printf("1+...+5=%d\n", 1+2+3+4+5);

2)

       int i = 2, sum = 1;

       sum = sum + i;  //1+2

       ++i;

       sum = sum + i;  //3+3

       ++i;

       sum = sum + i;  //6+4

       ++i;

       sum = sum + i;  //10+5

       printf("1+...+5=%d\n", sum);

3)

int i = 2, sum = 1;

       while(i <= 5)

       {

              sum = sum + i;

              ++i;

       }

       printf("1+...+5=%d\n", sum);

4.l输入一个正整数,输出各位上的数字和。请分析比较下面的三种算法。

1)

#include <stdio.h>

void main()

{

       int n;

    scanf("%d", &n);         

       printf("各位数字和为%d\n", n%10+n/10%10+n/100);             

}

2)

#include <stdio.h>

void main()

{

       int n, m, sum = 0;

    scanf("%d", &n);

       m = n % 10;

       sum += m;

       n /= 10; 

    m = n % 10;

       sum += m;

       n /= 10;    

       m = n % 10;

       sum += m;

       n /= 10;    

       printf("各位数字和为%d\n", sum);            

}

3)

#include <stdio.h>

void main()

{

       int n, m, sum = 0;

    scanf("%d", &n);

    while(n > 0)

       {

              m = n % 10;

              sum += m;

              n /= 10;     

       }

       printf("各位数字和为%d\n", sum);            

}

5. 有百余人(最多150人),2人一组余1人,3人一组余2人,5人一组余4人,6人一组余5人,7人一组正好分完,问共有几人?

5.1用穷举法猜出人数。

#include <stdio.h>

void main()

{

       int n;

    while(1>0)

       {

              scanf("%d", &n);

              if(n % 7 == 0 && n % 6 == 5 && n % 5 == 4)

                     if(n % 3 == 2 && n % 2 == 1)

                     {

                            printf("对了!就是%d人!\n", n);

                            return;

                     }

              printf("错了!不是%d人,请再继续!\n", n);

       }

}

如何提高穷举的效率,是100、101……,还是?

5.2用循环让程序自动穷举出答案。

转载地址:http://bddti.baihongyu.com/

你可能感兴趣的文章
Oracle 分组排序函数
查看>>
删除weblogic 域
查看>>
VMware Workstation 14中文破解版下载(附密钥)(笔记)
查看>>
日志框架学习
查看>>
日志框架学习2
查看>>
SVN-无法查看log,提示Want to go offline,时间显示1970问题,error主要是 url中 有一层的中文进行了2次encode
查看>>
NGINX
查看>>
Qt文件夹选择对话框
查看>>
1062 Talent and Virtue (25 分)
查看>>
1061 Dating (20 分)
查看>>
1060 Are They Equal (25 分)
查看>>
83. Remove Duplicates from Sorted List(easy)
查看>>
88. Merge Sorted Array(easy)
查看>>
leetcode刷题191 位1的个数 Number of 1 Bits(简单) Python Java
查看>>
leetcode刷题198 打家劫舍 House Robber(简单) Python Java
查看>>
NG深度学习第一门课作业2 通过一个隐藏层的神经网络来做平面数据的分类
查看>>
leetcode刷题234 回文链表 Palindrome Linked List(简单) Python Java
查看>>
NG深度学习第二门课作业1-1 深度学习的实践
查看>>
Ubuntu下安装Qt
查看>>
Qt札记
查看>>