iOS 阶段学习第四天笔记(循环)
iOS学习(C语言)知识点整理笔记
一、分支结构
1、分支结构分为单分支 即:if( ){ } ;多分支 即:if( ){ }else{ } 两种
2、单分支 if表达式成立则执行{ }里的语句;双分支 if表达式不成立 则执行else{ }里面的语句
3、字符串的输出系统会从数组地址一直打印到字符 ‘\0’为止,如果没有正确初始化,可能会打印出数组外的信息
4、如果分支结构里面只有一条执行语句可省略外面的大括号{} .
二、开关语句
1、语句结构 :switch (参数) case 常量: 执行语句;break;default: 执行语句;break; case 后面必须是常量且不能重复
2、无特殊情况每个case后面必须加上break 不然会造成 case穿透 执行
3、default 一般建议保留 用于处理所有case不满足的条件
三、循环结构
1、循环:即在满足表达式条件的时候反复执行语句组 ;循环必须有退出条件否则就是死循环。
2、循环类型:for( 初始化语句1; 条件判断语句2; 语句3){ 执行语句} ;while(条件语句){执行语句};do{ 执行语句}while(条件语句);
3、循环体中 continue 表示跳过当前条件内容执行下次循环 break表示结束整个循环
4、do while 第一次循环的时候,先执行语句后做判断,至少执行一次。
5、while 与 do while 在循环之前必须先初始化 ,for 循环自身已经包含初始化语句。
四、goto 跳转语句
1、goto 表示无条件跳转到一个标签,尽量避免使用 ,缺点:使代码目录不清晰,破坏层次感
2、goto 实例代码:
//使用goto语句 实现1~100求和
1 int main(){
int sum = ;
int i = ;
ADD:
sum +=i;
i++;
if(i<=){
goto ADD;//跳到标签号所在行,往下执行
}
printf("sum=%d\n",sum);
return ;
}
五、循环练习题
1、计算当前输入字符中数字、大/小字母、其他字符 个数
实现代码:
int main(){
int sz=,xz=,dz=,qt=;
char ch;
while ((ch=getchar())!='\n') {
if(ch>=''&&ch<='')
sz++;
else if(ch>='a'&&ch<='z')
xz++;
else if (ch>='A'&&ch<='Z')
dz++;
else
qt++;
}
printf("共输入了%d个数字字符\n",sz);
printf("共输入了%d个小写字母字符\n",xz);
printf("共输入了%d个大写字母字符\n",dz);
printf("共输入了%d个其他字符\n",dz);
return ;
}
2、输出九九乘法表
1x1=1,
2x1=2,2x2=4
3x1=3,3x2=6,3x3=9
4x .....
实现代码:
int main(){
for (int i=; i<=; i++) {
for (int j=; j<=i; j++) {
printf("%dx%d=%d\t\t",i,j,i*j);
}
printf("\n");
}
return ;
}
3、输出1~100的所有质数 (质数:即除1以外只能被1和它本身整除的数)
实现代码:
int main(){
for (int i=; i<=; i++) {
for (int j=; j<=i; j++) {
if(j==)
continue;
if(i%j==)
{
if(i!=j)
{
//printf("%d不是质数\n",i);
break;
}
else
{
printf("%d是质数\n",i);
break;
}
}
}
}
return ;
}
4、一球从 100 米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10 次落地时,共经过多少米
实现代码:
int main(){
float hight=,num=,sumh=;
for (int i=; i<=num; i++) {
sumh+=hight;
hight/=;
printf("第%d次回落(%.1f)米\n",i,hight);
}
printf("总共经过(%.1f)米",sumh);
return ;
}
5、使用辗转相除求两个数的最大公约数
实现代码:
int main(){
//(28,35)=(35,28)=(28,7)=0
int m,n,temp,rst;
printf("请输入两个数字:\n");
scanf("%d %d",&m,&n);
while(m%n!=){
if(m%n==m)
{
temp=m;
m=n;
n=temp;
rst=m%n;
printf("m=%d,n=%d\n",m,n);
}else {
rst=m%n;
m=n;
n=rst;
printf("m=%d,n=%d\n",m,n);
}
}
printf("%d",n);
return ;
}
6、将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5
实现代码:
int main(){
int v;
scanf("%d",&v);
printf("%d=",v);
for (int i=; i<=v; i++) {
while (v%i==) {
if(i<v)
printf("%d*",i);
else
printf("%d",i);
v/=i;
}
}
return ;
}
7、流程控制(for求阶乘的和 )输入n(int类型),打印1!+2!+3!+4!+5!+....+n!的值
实现代码:
int main(){
//例如 5的阶乘和=1*1 +2*2 +3*3*3+ 4*4*4*4 +5*5*5*5*5
int n,temp=,sum=;
scanf(“%d”,&n);
for (int i=; i<=n; i++) {
temp=;
for (int j=; j<=i; j++) {
temp*=i;
}
sum+=temp;
}
printf("sum=%d",sum);
return ;
}
8、整数逆序输出, 例如输入一个整数12345,输出54321
实现代码:
int main(){
int a;
scanf("%d",&a);
while(a/!=){
printf("%d ",a%);
a/=;
}
printf("%d ",a%);
return ;
}
9、流程控制(for循环)输出字母三角形 输入一个大写字母,如F输出:
A
ABA
ABCBA
ABCDCBA
ABCDEDCBA
ABCDEFEDCBA
实现代码 :
int main(){
char ch='A';
for (int i=; i<='F'-ch; i++) {
for (int n='F'-ch-i; n>; n--) {
printf(" ");
}
for (int j=; j<=i; j++) {
printf("%c",ch+j);
}
for (int m=i;m> ;m-- ) {
printf("%c",ch+m-);
}
printf("\n");
}
return ;
}
10、流程控制(for循环),输出字母序列比如输入:F
输出:
FEDCBA
EDCBAB
DCBABC
CBABCD
BABCDE
ABCDEF
实现代码:
int main(){
char sh,nsh,bsh;
printf("请输入一个字符:");
scanf("%c",&sh);
bsh=sh;
int len=sh-'A';
for (int i=; i<=len; i++) {
sh=bsh-i;
//nsh=bsh-len+1;
for (int j=; j<=i; j++) {
printf(" ");
}
for (int n=i; n<=len; n++) {
printf("%c", sh--);
}
nsh=sh+;
for (int m=; m<i; m++) {
printf("%c", nsh++);
}
printf("\n");
}
return ;
}
11、 输入一个日期年月日, 计算这一天是一年中的第几天(考虑闰年)
实现代码:
int main(){
int year,month,day,total=;
scanf("%d%d%d",&year,&month,&day);
if (year<=)
printf("请输入正确年份。");
for (int i=; i<month; i++) {
switch (i) {
case :
case :
case :
case :
case :
case :
case :
total+=;
break;
case :
case :
case :
case :
total+=;
break;
case :
if ((!(year%)&&year%)||!(year%))
total+=;
else
total+=;
break;
}
}
total+=day;
printf("%d年的第%d天",year,total);
return ;
}
12、猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘了多少。
实现代码:
int main(){
//分析: 第十天 1 第九天:4 第八天:10 第七天:22
int sum=,i,index=;
for(i=;i<=;i++)
{
printf("第%d天有桃%d个\n",index,sum);
sum=(sum+)*;
index--;
}
printf("猴子共摘了%d个桃子。\n",sum);
return ;
}
iOS 阶段学习第四天笔记(循环)的更多相关文章
- iOS阶段学习第四天笔记(循环)
iOS学习(C语言)知识点整理笔记 一.分支结构 1.分支结构分为单分支 即:if( ){ } ;多分支 即:if( ){ }else{ } 两种 2.单分支 if表达式成立则执行{ }里的语句:双 ...
- iOS阶段学习第33天笔记(自定义标签栏(UITabBar)介绍)
iOS学习(UI)知识点整理 一.自定义标签栏 1.方法一 单个创建标签栏 #import "AppDelegate.h" #import "SecondViewCont ...
- iOS阶段学习第三天笔记(运算符)
iOS学习(C语言)知识点整理笔记 1.运算符 一.算术运算符 1)表达式由变量.常量.运算符构成,有确定的类型和值 2)算术运算符包括: +(加),-(减),*(乘),/(除),%(模) 3)算术运 ...
- iOS 阶段学习第三天笔记(运算符)
iOS学习(C语言)知识点整理笔记 1.运算符 一.算术运算符 1)表达式由变量.常量.运算符构成,有确定的类型和值 2)算术运算符包括: +(加),-(减),*(乘),/(除),%(模) 3)算术运 ...
- iOS阶段学习第32天笔记(页面传值方法介绍)
iOS学习(UI)知识点整理 一.界面传值方法 1.方法一 Block传值 通过SubView视图的Block向View视图传值改变View视图的背景色 实例代码: 1)SubViewContro ...
- iOS阶段学习第26天笔记(UILabel的介绍)
iOS学习(UI)知识点整理 一.关于UILabel的使用介绍 1)概念:UILabel是一个继承自UIView的用于展示文本信息的控件 2)UI中所有的控件都继承自UIView 即UIView 是U ...
- iOS阶段学习第20天笔记(MRC内存管理)
iOS学习(OC语言)知识点整理 一.OC中的内存管理 1)概念:内存管理的对象为所有继承了NSObject的对象,对基本数据(如:int .float.double...)无效 OC中采用 ...
- iOS阶段学习第17天笔记(NSFileManager-NSFileHandle-文件操作)
iOS学习(OC语言)知识点整理 一.单例模式 1)单例是一种编程思想,一个设计模式,与语言无关在采用了单例对象的应用程序中,需要单例类自行提供实例化单例对象, 不管实例化单例对象多少次,只有一个对象 ...
- iOS阶段学习第16天笔记(Category-NSSet-SEL-NSIndexSet 操作)
iOS学习(OC语言)知识点整理 一.NSSet.NSMutableSet集合的介绍 1)NSSet.NSMutableSet集合,元素是无序的,不能有重复的值. 2)用实例方法创建一个不可变集合对象 ...
随机推荐
- 5309 《Java程序设计》第6周学习总结
教材学习内容总结 输入与输出 InputStream与OutputStream 从应用程序角度来看,如果要将数据从来源取出,可以使用输入串流:如果要将数据写入目的地,可以使用输出串流.在Java中,输 ...
- 20145310《Java程序设计》第3周学习总结
20145310 <Java程序设计>第3周学习总结 教材学习内容总结 本周学习内容比较多,主要是第四第五章的学习. 第四章 类与对象 类是对象的设计图,对象是类的实例. 类(Class) ...
- 20135302魏静静——linux课程第三周实验及总结
linux课程第三周实验及总结 一.实验:跟踪分析Linux内核的启动过程 使用gdb跟踪调试内核从start_kernel到init进程启动 使用实验楼的虚拟机打开shell cd LinuxKer ...
- 如何使用openwrt下的分区表生成器ptgen
1.基本用法如下: ptgen [-v] -h <heads> -s <sectors> -o <outputfile> [-a 0..4] [-l <ali ...
- [BZOJ2091]The Minima Game
Description 给出N个正整数,AB两个人轮流取数,A先取.每次可以取任意多个数,直到N个数都被取走.每次获得的得分为取的数中的最小值,A和B的策略都是尽可能使得自己的得分减去对手的得分更大. ...
- 浅析ProcessBuilder
概述 ProcessBuilder类是J2SE 1.5在java.lang中新添加的一个新类,此类用于创建操作系统进程,它提供一种启动和管理进程(也就是应用程序)的方法.在J2SE 1.5之前,都是由 ...
- mybatis的一级缓存和二级缓存(1)
1.mybatis一级缓存,sqlSesion级别的缓存,一级缓存默认一直开启的,sqlSession级别的一个Map,把查询的数据放到一个Map中,以后需要相同的数据,直接从Map中去取 与数据库一 ...
- hadoop项目实战--ETL--(二)实现自动向mysql中添加数据
四 项目开发 1 创建数据库db_etl,新建两张表user 和oder.表结构如第一部分图所示. 2 编写python脚本,实现自动向mysql中插入数据. 新建python 项目,目录结构如下图 ...
- UVA 12657 Boxes in a Line(双向链表+小技巧)
题意:对于一行按照顺序排列盒子数字与位置都为 1,2,3,4....n 执行四种操作 c = 1 x 放到 y 的左边 c =2 x 放到 y 的右边 c =3 交换 x, y c =4 ...
- Vjudge - B - 这是测试你会不会排序
2017-07-14 22:44:11 writer:pprp 题目: 他们提出的比赛规则是这样的: 1. 每方派出n个人参赛: 2. 出赛的顺序必须是从弱到强(主要担心中国人擅长的田忌赛马): ...