前言:感谢老铁的浏览,希望老铁可以一键三连加个关注,您的支持和鼓励是我前进的动力,后续会分享更多学习编程的内容。
 
 
一. 主干知识的学习
1. while语句
除了for语句以外,while语句也用于实现循环,而且它的适用面更广,其一般形式为:
while(表达式)
循环体语句
while语句的执行流程:当表达式的值为‘真’时,循环执行,直到表达式的值为‘假’,循环中止并继续执行while的下一条语句。
下面是while语句和for语句的流程对比图:
 
 
注意:for语句和while语句均能实现循环。但一般情况下,如果题目中指定了循环的次数,使用for语句更加清晰,循环的4个组成部分一目了然;其他情况一般使用while语句。
2.do-while语句
do-while语句与上述两种循环语句略有不同,它先执行循环体,后判断循环条件。所以无论循环条件的值如何,至少会执行一次。其一般形式为:
do{
循环体语句
}while(表达式);
执行流程:第一次进入循环时,首先执行循环体语句,然后再检查循环控制条件,即计算表达式,若值为‘真’,继续循环,直到表达式的值为‘假’,循环结束,执行下一条语句。
do-while语句的流程图:

3.break语句
break语句强制循环结束,for循环中的break语句的执行流程如下图,一旦执行了break语句,循环提前结束,不再执行循环体中位于其后的其他语句。
for结构中break的作用:
 
 
4.continue语句
continue语句的作用是跳出循环体中continue后面的语句,继续下一次循环,其工作流程如图:
 
 
注意:continue语句与break语句的区别在于,break结束循环,而continue只是跳过后面语句继续循环。break除了可以中止循环外,还用于switch语句,而continue只能用于循环。
二. 具体问题中的应用
问题1:用格雷戈里公式求给定度的“值。使用格雷戈里公式求 的近似值,要求精确到最后一项的绝对值小于给定精度 eps。
                                 丌/4=1-1/3+1/5-1/7+····· 
源程序:
#include <stdio.h>
#include <math.h>       //用于调用绝对值函数fabs() 
int main()
{int denominator,flag,i;double eps,item,pi;   //pi用于存放累加和 printf("Enter eps:");  //输入所需精度 scanf("%lf", &eps);i=1;   //i表示项数 flag=1;  //flag用于改变符号 denominator=1;  //denominator表示第i项分母 item=1.0;  //item为第i项的值 pi=0;while(fabs(item)>=eps)  //循环条件 {pi=pi+item;  //逐项累加 i++;flag=-flag;denominator=denominator+2;item=flag*1.0/denominator;}pi=pi+item;  //加上最后一项的值 pi=pi*4;  //最终结果 printf("pi=%.6f\n", pi);  //保留6位小数 printf("i=%d\n", i);  //输出项数 return 0;} 注意:这里第i项用变量item表示,一旦某一项的绝对值小于eps,就达到了所给的精度,由于最后一项的绝对值小于eps,所以最后还需要加上最后一项的值。
问题2:统计一个整数的位数。从键盘读入一个整数,统计该数的位数。例如,输入12534,输出5;输入-99,输出2;输入0,输出1。
源程序:
#include <stdio.h>
int main()
{int count,number,t_number;   //count记录整数number的位数 count=0;printf("Enter a number:");scanf("%d", &number);t_number=number;  //保护输入数据不被改变 if (number<0){t_number=-t_number;  //将输入的负数转换为正数 }do{count++;  t_number=t_number/10;  //整除后减少一个个位数,组成一个新数 }while(t_number!=0);  //循环条件,控制循环的结束 printf("It contains %d digits.\n", count);return 0;} 
问题3:判断一个整数是否为素数。输人一个正整数 m,判断它是否为素数。素数就是只能被 1和自身整除的正整数,1 不是素数,2 是素数。
源程序:
#include <stdio.h>
#include <math.h>
int main()
{int i,limit,m;printf("Enter a number:");scanf("%d", &m);if (m<=1)  //小于等于1的不是素数 {printf("No!\n");}else if (m==2)   //2是素数 {printf("%d is a prime number!\n", m);}else{limit=sqrt(m)+1;for (i=2; i<=limit; i++){if (m%i==0)  //若m能被某个i整除,则m不是素数 {break;}}if (i>limit)  //循环结束,说明m不能被任何一个i整除 {printf("%d is a prime number!\n", m);}else {printf("No!\n"); }}return 0;} 
感谢您的关注哦,我会持续更新编程相关知识,愿您在这里有所收获。如果有任何问题,欢迎沟通交流!期待与您在学习编程的道路上共同进步。
