一、for循环拥有两类:
(一)、穷举:
把所有可能的情况都走一遍,使用if条件筛选出来满足条件的情况。
1.单位给发了一张150元购物卡,拿着到超市买三类洗化用品。洗发水15元,香皂2元,牙刷5元。求刚好花完150元,有多少种买法,没种买法都是各买几样?
int ci = 0;
int biao = 0;//标记变量
for (int x = 0; x <= 10; x++)
{
for (int y = 0; y <= 30; y++)
{
for (int z = 0; z <= 75; z++)
{
ci++;
if (15 * x + y * 5 + z * 2 == 150)
{
biao++;
Console.WriteLine("第{0}种买法:洗发水{1}瓶,牙刷{2}支,香皂{3}块。", biao, x, y, z);
}
}
}
}
Console.WriteLine("总共有{0}种买法。", biao);
Console.WriteLine(ci);
Console.ReadLine();
2.百鸡百钱:公鸡2文钱一只,母鸡1文钱一只,小鸡半文钱一只,总共只有100文钱,如何在凑够100只鸡的情况下刚好花完100文钱?(或者大马驼2石粮食,中等马驼1石粮食,两头小马驼1石粮食,要用100匹马,驼100石粮食,该如何分配?)
int ci = 0;
for (int x = 0; x <= 50; x++)
{
for (int y = 0; y <= 100; y++)
{
for (int z = 0; z <= 200; z++)
{
if (2 * x + y + z * 0.5 == 100 && x + y + z == 100)
{
Console.WriteLine("公鸡{0}只,母鸡{1}只,小鸡{2}只。", x, y, z);
ci++;
}
}
}
}
Console.WriteLine(ci);
Console.ReadLine();
3. 有1分钱,2分钱,5分钱的硬币,要组合出来2角钱,有几种组合方式,分别各多少个?
int ci = 0;
for (int x = 0; x <= 100; x++)
{
for (int y = 0; y <= 50; y++)
{
for (int z = 0; z <= 20; z++)
{
if (x + 2 * y + 5 * z == 100)
{
Console.WriteLine("1分钱{0}枚,2分钱{1}枚,5分钱{2}枚。", x, y, z);
ci++;
}
}
}
}
Console.WriteLine(ci);
Console.ReadLine();
(二)、迭代:
从初始情况按照规律不断求解中间情况,最终推导出结果。
1.五个小朋友排成一队,问第一个多大了,第一个说比第二个大两岁,问第二个多大了,第二个说比第三个大两岁。。。以此类推,问第5个小朋友,说自己3岁了。问第一个小朋友几岁了?
int sum = 3;
for (int i = 1; i < 5; i++)
{
sum += 2;
}
Console.WriteLine(sum);
Console.ReadLine();
2.纸张可以无限次对折,纸张厚度为0.07毫米。问多少次对折至少可以超过8848?
double height = 0.07;
int ci = 0;
while (height <= 8848000)
{
ci++;
height *= 2;
}
Console.WriteLine(ci);
Console.ReadLine();
二、while循环
while 循环,其实是for循环的变形写法
for(int i = 1; i<=5;i++)
{
循环体;
}
上面的for循环可以写成
int i= 1;
for(;i<=5;)
{
循环体;
i++;
}
写成while就是以下样式
int i= 1;
while(表达式(i<=5))//在括号内直接限制循环条件
{//需要在中括号内给出改变方式,否则将会进入死循环
循环体;
状态改变(i++);//在中括号内给予值得改变方式
}
跳转语句:
break:跳出整个循环
continue:跳出本次循环,继续下次循环。
注:●do
{
循环体;
状态改变(i++);
}while(表达式(i<=5))
注意:do while是不管满不满足表达式,我都会先执行一遍。
●while死循环
while (true)//死循环一
{
循环体;
状态改变;
}
while (1 == 1)//死循环二
{
循环体;
状态改变;
}
While循环例题:
1、100节楼梯,前50节每节分数等于阶梯数,当到第30节时直接跳到第50节得100分, 51节开始每节10分
int n = 0;
int m = 0;
while (n < 100)
{
n++;
if (n <= 30)
{
m = m + n;
Console.WriteLine("到{0}层时的分数是{1}。", n, m);
}
if (n > 30 && n <= 50)
{
if (n == 50)
{
m += 100;
Console.WriteLine("到50层的分数" + m);
}
continue;
}
if (n > 50)
{
m += 10;
Console.WriteLine("到{0}层时的分数是{1}。", n, m);
}
}
Console.ReadLine();
2、do while
增补循环语句一——for循环
1、有一对幼兔,幼兔1个月后长成小兔,小兔1个月后长成成兔并生下一对幼兔,问几年后有多少对兔子,幼兔、小兔、成兔对数分别是多少。成兔每月生下一对幼兔。
成兔对数 |
0 |
0 |
1 |
1 |
2 |
3 |
5 |
小兔对数 |
0 |
1 |
0 |
1 |
1 |
2 |
3 |
幼兔对数 |
1 |
0 |
1 |
1 |
2 |
3 |
5 |
月份 |
1 |
2 |
3 |
4 |
5 |
6 |
7 |
总对数 |
1 |
1 |
2 |
3 |
5 |
8 |
13 |
根据上表可以得到结论:
本月的成兔=上月的小兔+上月的成兔。
本月的小兔=上月的小兔。
本月的幼兔=本月的成兔。
Console.Write("请输入月数:");
int m = int.Parse(Console.ReadLine ());
int a = 0, b = 0, c = 1, d = 1;
int i = 1;
for (; i <= m; i++)
{
if (i == 1)
{
a = 0;
b = 0;
c = 1;
}
else
{
a = b + a;
b = c;
c = a;
}
d = a + b + c;
}
Console.WriteLine("{0}个月后成兔对数是{1}", i, a);
Console.WriteLine("{0}个月后小兔对数是{1}", i, b);
Console.WriteLine("{0}个月后幼兔对数是{1}", i, c);
Console.WriteLine("{0}个月后兔总对数是{1}", i, d);
Console.ReadLine();
C#语句2——循环语句(for穷举、迭代和while循环)的更多相关文章
-
循环语句while与for的穷举迭代
循环语句while while当...的时候 int n=1; while(n<6)//在括号内直接限制逻辑关系 {//需要在大括号内给出改变方式,否则将进入死循环 console.WriteL ...
-
C# 循环语句 for循环(嵌套 while 穷举 迭代)
for循环的嵌套类似于if else 事例: 打印矩阵,外循环对应行,内循环对应列 for (int k = 1; k <= 5; k++) { for (int i = 1; i <= ...
-
6、C#基础整理(for 语句经典习题--for循环嵌套、穷举)
1.for循环嵌套----最基础题目:求阶乘的和 ; int n = int.Parse(Console.ReadLine()); ; i < n; i++) { ;//定义变量sum1,每次循 ...
-
穷举法、for循环、函数、作用域、斐波那契数
1.穷举法 枚举所有可能性,直到得到正确的答案或者尝试完所有值. 穷举法经常是解决问题的最实用的方法,它实现起来热别容易,并且易于理解. 2.for循环 for语句一般形式如下: for variab ...
-
for循环的嵌套,for循环的穷举迭代
for循环的嵌套 输入一个正整数,求阶乘的和 嵌套 Console.Write("请输入一个正整数:"); int ...
-
for循环嵌套的穷举,迭代,以及while的使用和for的转换
for循环的穷举.解决多种方法做种组合问题,代替人脑的大量计算 穷举例子 迭代,寻找一定的规律.然后利用循环找出结果 迭代举例 以五个小朋友3岁,之前的每一个小朋友都比序号在后的小朋友大两岁.温,第一 ...
-
while、dowhile、switchcase 循环嵌套、穷举、迭代
for(var i=0;i<5;i++)//假如规定到5 { document.write("123456<br/>") } 如果变成这样 var i=0: fo ...
-
穷举 迭代 while
for循环拥有两类: 穷举: 把所有可能的情况都走一遍,使用if条件筛选出来满足条件的情况. 例:1.单位给发了一张150元购物卡,拿着到超市买三类洗化用品.洗发水15元,香皂2元,牙刷5元.求刚好花 ...
-
java,for循环中的穷举、迭代、冒泡例题
1.100以内与7相关的数 //100以内与7相关的数: public static void main1(String[] args) { for(int i=1;i<=100;i++){ i ...
-
for循环语句以及迭代法和穷举法
循环语句: 四要素:初始条件,循环条件,状态改变,循环体 for(初始条件;循环条件;状态改变){ //循环体} 案例1:打印等腰直角三角形和菱形 左上三角 static void Main(stri ...
随机推荐
-
Drop it
FCC题目:队友该卖就卖,千万别舍不得. 让我们来丢弃数组(arr)的元素,从左边开始,直到回调函数return true就停止. 第二个参数,func,是一个函数.用来测试数组的第一个元素,如果返回 ...
-
开发webservice的方式
什么是 web 服务? web 服务是对应用程序功能的网络访问接口,它是使用标准 Internet 技术构建的. 我们目前看到的部署在 Internet 上的 web 服务都是 HTML 网站 ...
-
Django 中url补充以及模板继承
Django中的URL补充 默认值 在url写路由关系的时候可以传递默认参数,如下: url(r'^index/', views.index,{"name":"root& ...
-
apache安装后编译新模块
1.下载对应版本的源码包 2.解压后找到modules/mappers目录并进入 3.运行如下命令自动编译.安装和修改httpd.conf文件: /usr/sbin/apxs -c -i -a mod ...
-
C++辛格尔顿
设计模式是编程的焦点.经常在面试时进行审查,Singleton模式是最简单的.最常见的.大部分的主模式.所以大部分的采访是测试考试的Singleton设计模式. 以下我们就来看看单例模式怎样实现(C+ ...
-
基于NIOS-II的示波器:PART1 按键&显示屏驱动&界面
NIOS II 相关资料以及基础入门 <NiosII的奇幻漂流> <Nios II那些事儿> 本文所有的硬件基础以及工程参考来自魏坤示波仪,重新实现驱动并重构工程. 基于NIO ...
-
PHP连接mysql数据库进行增删改查--删除
删除: 1.首页 在foreach里面加入 <td><a href='dele.php?id={$i[0]}'>删除</a></td> 在上面< ...
-
JDK1.8中的线程池
上面这段代码一直在用,面试的时候也经常被问到,却从未深究过,不知道线程池到底是怎么回事,今天看看源代码,一探其究竟 线程池主要控制的状态是ctl,它是一个原子的整数,其包含两个概念字段: worker ...
-
关于11G DataGuard 日志传输的案例
案例探讨 在归档和非归档模式下,配置参数log_archive_dest_2后,DG的备库是否传输日志. 案例环境描述 本次环境如下,一套RAC+单机DG,然后从DG还原出来一个单独的测试库A,测试库 ...
-
VMware安装xp虚拟机
VMware安装xp虚拟机 1.用到的软件: 2.安装VMware: 接受 选择自定义 要等上一小会. 输入密钥:百度一个就可以了. 安装成功: 禁用VMware网卡: 3.安装xp系统: 创建新的 ...