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 ...
随机推荐
- Canu FAQ常见问题
链接:Canu FAQ Q: What resources does Canu require for a bacterial genome assembly(细菌基因组组装)? A mammal ...
- 在XP下把win7安装到VHD,内存足够大可以RAMOS
在XP下把win7安装到VHD,内存足够大可以RAMOS1.用DiskGenius创建VHD固定大小磁盘文件,以win7vhd.vhd为例,然后进行分区格式化,格式化时启用NTFS压缩.2.进入WIN ...
- python 暴力破解密码脚本
python 暴力破解密码脚本 以下,仅为个人测试代码,环境也是测试环境,暴力破解原理都是一样的, 假设要暴力破解登陆网站www.a.com 用户 testUser的密码, 首先,该网站登陆的验证要支 ...
- hdu----(1466)计算直线的交点数(dp)
计算直线的交点数 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Su ...
- Eclipse上安装GIT插件EGit
一.Eclipse上安装GIT插件EGit Eclipse的版本eclipse-java-helios-SR2-win32.zip(在Eclipse3.3版本找不到对应的 EGit插件,无法安装) E ...
- 128. Longest Consecutive Sequence *HARD* -- 寻找无序数组中最长连续序列的长度
Given an unsorted array of integers, find the length of the longest consecutive elements sequence. F ...
- Java 多线程 —— synchronized关键字
java 多线程 目录: Java 多线程——基础知识 Java 多线程 —— synchronized关键字 java 多线程——一个定时调度的例子 java 多线程——quartz 定时调度的例子 ...
- .NET GC机制学习笔记
学习笔记内容来自网络资料摘录http://www.cnblogs.com/springyangwc/archive/2011/06/13/2080149.html 1.GC介绍 Garbage Col ...
- postgres 正则表达式
PostgreSQL正则表达式 基础: Operator Description Example ~ Matches regular expression, case sensitive 'thoma ...
- 328. Odd Even Linked List——多利用fake_head
Given a singly linked list, group all odd nodes together followed by the even nodes. Please note her ...