【引例】 输出一行10个“*”

#include<cstdio>
int main(){
printf("**********\n");
return ;
}

思考:

(1)输出一行100个“*”

(2)输出一行1000个“*”

(3)输出……

引入for

#include<cstdio>
int main(){
for (int i=;i<=;i++)
printf("*");
return ;
}

要求:单步执行,观察循环控制变量i的变化。

【例1】输出1,2,3…,10,每个数字一行。

for的格式1:

for (控制变量初始化;条件表达式;增量表达式)

<一条语句>;

for的格式2:

for (控制变量初始化;条件表达式;增量表达式)

{

语句1;

语句2;

……

}

for语句执行过程:

(1)执行“控制变量初始化”语句,使控制变量获得一个初值。

(2)判断控制变量是否满足“条件表达式”,若满足条件则执行一遍循环体,否则跳到步骤5。

(3)根据增量表达式,计算出控制变量所得到的新值

(4)自动转到第(2)步。

(5)循环结束,执行for循环后面的语句。

【例2】键入一个自然数n,求s=1+2+...+n的值

如:

输入:

100

输出:

5050

#include<cstdio>
int main(){
int s=, n;
scanf("%d",&n);
for (int i=;i<=n;i++)
s=s+i;
printf("%d\n",s);
return ;
}

【例2拓展】 键入一个自然数n(<10000),求这个自然数的所有约数之和S (n的约数不包含1和n)。

如:

输入:

6

输出:

5

#include<cstdio>
int main(){
int s=,n;
scanf("%d",&n);
for (int i=; i<=n-;i++)
if (n%i==) s=s+i;
printf("%d ",s);
return ;
}

【例3】输入正整数n(<1000000),判断它是否为素数。是素数输出”yes”,不是素数输出”no”.素数也称为质数。

程序1(例二的延伸)

#include<cstdio>
int main(){
int s=,n;
scanf("%d",&n);
for (int i=; i<=n-;i++)
if (n%i==) s=s+i;
if (s==) printf("yes");
else printf("no");
return ;
}

程序2(使用标志变量,添加break):

#include<cstdio>
int main(){
int n,f=;
scanf("%d",&n);
for (int i=; i<=n-;i++)
if (n%i==) {
f=; }
if (f==) printf("yes");
else printf("no");
return ;
}

尝试:n=1000000007

程序3(提高程序效率)

#include<cstdio>

#include<cmath>

int main(){

  int n,m,f=;

  scanf("%d",&n);

  m= floor(sqrt(n)+0.5);

  for (int i=; i<=m;i++)

     if (n%i==) {

       f=;

       break;

  }

  if (f==) printf("yes");

  else printf("no");  

  return ;

}

知识补充:floor(x)返回不超过x的最大整数

思考:循环结束时变量i的值是多少,输出结果验证和你的猜测。

程序4(灵活利用for循环)

#include<cstdio>
#include<cmath>
int main(){
int i,n,m;
scanf("%d",&n);
m=floor(sqrt(n)+0.5);
for (i=; i<=m&&n%i!=;i++);
if (i==m+) printf("yes");
else printf("no");
return ;
}

注意:

在for循环“控制变量初始化语句”中声明的变量,这些变量只在for循环结构中有效,离开了该for结构,变量就无效了。

练习1. 编一个程序,从键盘输入一个分数的分子a和分母b(a<b),输出它的小数形式,精确到小数点后n位。a,b,n<1000,不考虑四舍五入。

练习2.

数列的前两项分别是1、1,从第三项开始,每个数均为前面两项的和,即: 1,1,2,3,5,8,…。

输入:n

输出:数列第n项的值,n<=90

如:

输入:6

输出:8

for循环进阶的更多相关文章

  1. 大数据之路day04_1--数组 and for循环进阶

    Java数组 在开始之前,提一个十分重要的一点:注意:在给数组分配内存空间时,必须指定数组能够存储的元素来确定数组大小.创建数组之后不能修改数组的大小,可以使用length属性获取数组的大小.在jav ...

  2. 【Python】学习笔记十四:循环进阶

    range() 在Python中,for循环后的in跟随一个序列的话,循环每次使用的序列元素,而不是序列的下标. 我们继续开发range的功能,以实现下标对循环的控制: s = 'abcdefghj' ...

  3. 事件循环进阶:macrotask与microtask

    这段参考了参考来源中的第2篇文章(英文版的),(加了下自己的理解重新描述了下), 这里没法给大家演示代码,我就简单说下我的理解吧. promise和settimeout 在一起的时候执行顺序是个有意思 ...

  4. Python之while循环

    1.While循环基础 2.While循环进阶 3.其他

  5. JavaScript的for循环

    1.循环的目的 什么是循环?循环的目的是什么?循环能做什么? 举一个小例子:武汉疫情,学了JavaScript,必须拿JavaScript干点有意义的事情.我们想告诉武汉:“武汉加油,武汉挺住啊!”. ...

  6. 从浏览器多进程到JS单线程,JS运行机制的一次系统梳理

    前言 见解有限,如有描述不当之处,请帮忙及时指出,如有错误,会及时修正. ----------超长文+多图预警,需要花费不少时间.---------- 如果看完本文后,还对进程线程傻傻分不清,不清楚浏 ...

  7. 从浏览器多进程到JS单线程,JS运行机制最全面的一次梳理

    前言 来源:https://dailc.github.io/2018/01/21/js_singlethread_eventloop.html 见解有限,如有描述不当之处,请帮忙及时指出,如有错误,会 ...

  8. ansible-play中for,if的使用

    #迭代循环的使用 #实现同时新建三个文件,同时部署三个服务 --- - host: websrvs remote_user: root task: - name: create some files ...

  9. 使用C#开发数据库应用程序

    第一章 用Hello ACCP.NET快速热身(一) 1-1.进入C#世界 a.第一个C#程序 (1)新建项目[项目:project] (2)生成解决方案[生成:build,解决方案:solution ...

随机推荐

  1. java 集合(set)

    Interface ListIterator<E> 特有的方法: hasPrevious() 判断是否存在上一个元素. previous() 当前指针先向上移动一个单位,然后再取出当前指针 ...

  2. b.BIO连接器整体框图

    上一讲讲解过NIO的框图,可以看来,NIO通道是目前Tomcat7以后的默认的通道的推荐配置,在Tomcat6和以前的配置中,BIO是主流的配置: 只需要修改protocol协议部分即可,而后续还有A ...

  3. 阿里Linux Shell脚本面试25个经典问答

    转载: 阿里Linux Shell脚本面试25个经典问答 Q:1 Shell脚本是什么.它是必需的吗? 答:一个Shell脚本是一个文本文件,包含一个或多个命令.作为系统管理员,我们经常需要使用多个命 ...

  4. swiper轮播图--兼容IE8

    //引入idangerous.swiper.min.js var mySwiper = new Swiper ('.swiper-container', { loop: true, paginatio ...

  5. robotframework笔记19

    后处理输出 使用时自动测试 在测试执行报告和日志生成,并使用它 分别允许创建自定义报告和日志以及结合 和合并的结果. 使用Rebot 简介 rebot [options] robot_outputs ...

  6. 《构建之法》第8、9、10章读后感和Sprint总结

    <构建之法>第8.9.10章读后感  第八章重点讲了需求分析,在一个项目中,需求分析是最基础也是最重要的,只有充分了解了用户需求,我们才不会走弯路,才能做出正确的规划,保证项目的进行是按照 ...

  7. javaSE基础——常见的dos命令即其他

     常用的DOS命令 dir(directory) :    列出当前目录下的文件以及文件夹 md(make directory) : 创建目录 rd(remove directory) : 删除目录 ...

  8. IOS开发设计思路

    我在做 iOS 开发的时候,发现自己在写程序的时候,常常处于两种状态的切换,我把这两种状态称为软件开发的上帝模式与农民模式.我先给大家介绍一下这两种模式的特点. 上帝模式 处于上帝模式时,我需要构思整 ...

  9. Java 集合系列 17 TreeSet

    java 集合系列目录: Java 集合系列 01 总体框架 Java 集合系列 02 Collection架构 Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例 Java ...

  10. 最小生成树练习1(克鲁斯卡尔算法Kruskal)

    今天刷一下水题练手入门,明天继续. poj1861 Network(最小生成树)新手入门题. 题意:输出连接方案中最长的单根网线长度(必须使这个值是所有方案中最小的),然后输出方案. 题解:本题没有直 ...