for循环进阶
【引例】 输出一行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循环进阶的更多相关文章
- 大数据之路day04_1--数组 and for循环进阶
Java数组 在开始之前,提一个十分重要的一点:注意:在给数组分配内存空间时,必须指定数组能够存储的元素来确定数组大小.创建数组之后不能修改数组的大小,可以使用length属性获取数组的大小.在jav ...
- 【Python】学习笔记十四:循环进阶
range() 在Python中,for循环后的in跟随一个序列的话,循环每次使用的序列元素,而不是序列的下标. 我们继续开发range的功能,以实现下标对循环的控制: s = 'abcdefghj' ...
- 事件循环进阶:macrotask与microtask
这段参考了参考来源中的第2篇文章(英文版的),(加了下自己的理解重新描述了下), 这里没法给大家演示代码,我就简单说下我的理解吧. promise和settimeout 在一起的时候执行顺序是个有意思 ...
- Python之while循环
1.While循环基础 2.While循环进阶 3.其他
- JavaScript的for循环
1.循环的目的 什么是循环?循环的目的是什么?循环能做什么? 举一个小例子:武汉疫情,学了JavaScript,必须拿JavaScript干点有意义的事情.我们想告诉武汉:“武汉加油,武汉挺住啊!”. ...
- 从浏览器多进程到JS单线程,JS运行机制的一次系统梳理
前言 见解有限,如有描述不当之处,请帮忙及时指出,如有错误,会及时修正. ----------超长文+多图预警,需要花费不少时间.---------- 如果看完本文后,还对进程线程傻傻分不清,不清楚浏 ...
- 从浏览器多进程到JS单线程,JS运行机制最全面的一次梳理
前言 来源:https://dailc.github.io/2018/01/21/js_singlethread_eventloop.html 见解有限,如有描述不当之处,请帮忙及时指出,如有错误,会 ...
- ansible-play中for,if的使用
#迭代循环的使用 #实现同时新建三个文件,同时部署三个服务 --- - host: websrvs remote_user: root task: - name: create some files ...
- 使用C#开发数据库应用程序
第一章 用Hello ACCP.NET快速热身(一) 1-1.进入C#世界 a.第一个C#程序 (1)新建项目[项目:project] (2)生成解决方案[生成:build,解决方案:solution ...
随机推荐
- java 集合(set)
Interface ListIterator<E> 特有的方法: hasPrevious() 判断是否存在上一个元素. previous() 当前指针先向上移动一个单位,然后再取出当前指针 ...
- b.BIO连接器整体框图
上一讲讲解过NIO的框图,可以看来,NIO通道是目前Tomcat7以后的默认的通道的推荐配置,在Tomcat6和以前的配置中,BIO是主流的配置: 只需要修改protocol协议部分即可,而后续还有A ...
- 阿里Linux Shell脚本面试25个经典问答
转载: 阿里Linux Shell脚本面试25个经典问答 Q:1 Shell脚本是什么.它是必需的吗? 答:一个Shell脚本是一个文本文件,包含一个或多个命令.作为系统管理员,我们经常需要使用多个命 ...
- swiper轮播图--兼容IE8
//引入idangerous.swiper.min.js var mySwiper = new Swiper ('.swiper-container', { loop: true, paginatio ...
- robotframework笔记19
后处理输出 使用时自动测试 在测试执行报告和日志生成,并使用它 分别允许创建自定义报告和日志以及结合 和合并的结果. 使用Rebot 简介 rebot [options] robot_outputs ...
- 《构建之法》第8、9、10章读后感和Sprint总结
<构建之法>第8.9.10章读后感 第八章重点讲了需求分析,在一个项目中,需求分析是最基础也是最重要的,只有充分了解了用户需求,我们才不会走弯路,才能做出正确的规划,保证项目的进行是按照 ...
- javaSE基础——常见的dos命令即其他
常用的DOS命令 dir(directory) : 列出当前目录下的文件以及文件夹 md(make directory) : 创建目录 rd(remove directory) : 删除目录 ...
- IOS开发设计思路
我在做 iOS 开发的时候,发现自己在写程序的时候,常常处于两种状态的切换,我把这两种状态称为软件开发的上帝模式与农民模式.我先给大家介绍一下这两种模式的特点. 上帝模式 处于上帝模式时,我需要构思整 ...
- Java 集合系列 17 TreeSet
java 集合系列目录: Java 集合系列 01 总体框架 Java 集合系列 02 Collection架构 Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例 Java ...
- 最小生成树练习1(克鲁斯卡尔算法Kruskal)
今天刷一下水题练手入门,明天继续. poj1861 Network(最小生成树)新手入门题. 题意:输出连接方案中最长的单根网线长度(必须使这个值是所有方案中最小的),然后输出方案. 题解:本题没有直 ...