小学生都看得懂的C语言入门(2): 判别 循环的一些应用实例
1.bool 类型
定义bool类型之前需要导入#include <stdbool.h>
#include <stdio.h>
#include <stdbool.h>
int main()
{
bool b=>;
bool t=true;
printf("%d\n",b); //仍然是整数形式输出 得到1
return ;
}
2.逻辑运算
非! 或|| 和&& x>4 && x<6 !age<20 永远成立,!age=0或1 优先级顺序 ! && ||
赋值运算等级最低
// 短路 逻辑运算时从左向右的,左边已经可以觉得结果了,右边就不做了
//条件运算符 m<n? x:a+5 表示m<n 则 取x, 否则为a+5 ,这种表达式少用,会搞错 !!
//逗号 等级最低的
#include <stdio.h>
#include <stdbool.h>
int main()
{
int i=+, +; //出错了 为什么
printf("%d\n",i); //
int j=(+,+); // 正确
printf("%d\n",j); //
return ;
}
逗号什么用? 主要在for 中使用,可以放多个计算. for(i=0,j=10;i<j:i++,j--)...
3.分段函数
#include <stdio.h>
int main()
{
int x=;
int f=;
if (x<){
f=-;
}
else if(x==){
f=;
}
else{
f=*x;
}
printf("%d\n",f); //20
return ;
}
if else 后面只有一个执行语句的话,可以不加{}
#include <stdio.h>
int main()
{
int x=;
int f=;
if (x<)
f=-;
else if(x==)
f=;
else
f=*x;
printf("%d\n",f); //20
return ;
}
4.switch
为什么已经有了if 还需要用switch?
#include <stdio.h>
int main()
{
int type;
scanf("%d",&type); if (type==)
printf("nihao");
else if(type==)
printf("zaoshanghao");
else if(type==)
printf("wanshanghao") ;
else
printf("no") ; // 上述当type=4 需要一个一个判别过来,不太好 ,因此引入switch
return ;
}
用switch() {case 1:...; break; case 2:... ;break;...default:...;break;}
#include <stdio.h>
int main()
{
int type;
scanf("%d",&type);
switch(type){
case : //tpye=10 就直接做这个,
printf("nihao");
break; //一定要有break, 阻止语句往下执行
case :
printf("zaoshanghao");
break;
case : //tpye=30 就直接做这个,不用判别前面两种了
printf("wanshanghao");
break;
default:
printf("no");
return ;
}
注意: switch 只能用整数型, type不能是double!
#include <stdio.h>
int main()
{
//成绩转化
int grade;
scanf("%d",&grade) ;
grade/=;
switch(grade){
case :
case :
printf("A\n");
break;
case :
printf("B\n");
break;
case :
printf("C\n");
break;
case :
printf("D\n");
break;
default:
printf("F\n");
break;
}
return ;
}
5.简单小例子
#include <stdio.h>
int main()
{
// 计算log2的整数部分
int x;
int ret=;
scanf("%d",&x);
int t=x;
while(x>){
x/=;
ret++;
}
printf("log2 of %d is %d\n",t,ret);
return ;
}
12
log2 of 12 is 3
求平均数,输入数字, 以-1 结束,求出-1之前的平均数
#include <stdio.h>
int main()
{
int num;
int sum=;
int count=; scanf("%d",&num); while(num!=-){
sum+=num;
count++;
scanf("%d",&num);
} printf("%f\n",1.0*sum/count);
return ;
}
猜数字游戏 (1-100) 过程中需要提示:大了 小了,记录猜数字次数.
#include <stdio.h>
#include <stdlib.h> //rand 可以用了
#include <time.h>
int main()
{ srand(time()); //让随机数能够像随机数一样
int num=rand()%+; //产生一个1-100之间的随机数
int a=;
int count=; //猜数次数
printf("我已经想好了一个1到100内的数\n"); do{
printf("please guess a number:\n");
scanf("%d",&a);
count++; //无论对错都算一次
if (a>num)
printf("大了");
else if (a<num)
printf ("小了");
}while(a!=num); printf("bingo!,你用了%d次就成功了\n",count);
return ;
}
数字逆序输出 ,整数x逆序 作用x%10 得到个位数 x/10 去掉个位数,
#include <stdio.h>
int main()
{
int x=;
int t=x;
int num;
int ret=;
while(x>){
num=x%;
ret=ret*+num;
x/=;
}
printf("the reverse of %d is %d\n",t,ret);
return ;
}
the reverse of 500 is 5 , 没有得到005 有缺陷!
注意:容易出错的地方, if后面没有加{} 如果执行语句只有一句,可以不加,有多句一定要{} .
if() 后面不用加; 否则if 直接结束了,执行后面语句
#include <stdio.h>
int main()
{
int age=;
if (age>); //加了;
{
printf("can be treat carefully");
}
return ;
}
得到:
can be treat carefully 这个结果就是 if 在不执行设么就直接结束了,进入printf 语句
好的风格的代码.
#include <stdio.h>
int main()
{
int x=;
int f=;
if (x<)
{
f=-;
}
else if (x==)
{
f=;
}
else
{
f=*x;
}
return ;
}
上述优点在于如要注释几行不会影响其他行. 特别是{ }最会受注释行的影响.
//判断素数
#include <stdio.h>
int main()
{
int x;
scanf("%d",&x);
int i;
int isprime=;
for(i=;i<x;i++)
{
if(x%i==)
{
isprime=;
// break; break也可以放在外面
} break;
}
if(isprime==)
printf("不是素数");
else
printf("是素数");
return ;
}
13
是素数
//输出30以内的素数 双重循环
#include <stdio.h>
int main()
{
int x;
for(x=;x<;x++)
{
int i;
int isprime=;
for(i=;i<x;i++)
{
if(x%i==)
{
isprime=;
} break;
}
if(isprime==)
printf("%d ",x);
}
return ;
}
2 3 5 7 9 11 13 15 17 19 21 23 25 27 29
// 输出前20个素数
#include <stdio.h>
int main()
{
int x=;
int cnt=;
while(cnt<)
{
int i;
int isprime=;
for(i=;i<x;i++) //x还是会输出2的
{
if(x%i==)
{
isprime=;
} break;
}
if(isprime==)
{
printf("%d ",x);
cnt++;
}
x++;
}
return ;
}
2 3 5 7 9 11 13 15 17 19 21 23 25 27 29 31 33 35 37 39
//另一种方法, 不用while, 用for
#include <stdio.h>
int main()
{
int x;
int cnt=;
for(x=;cnt<;x++)
{
int i;
int isprime=;
for(i=;i<x;i++) //x还是会输出2的, 但是只有一次循环
{
if(x%i==)
{
isprime=;
} break;
}
if(isprime==)
{
printf("%d ",x);
cnt++;
}
}
return ;
}
//凑硬币 1 2 5元 凑成100元以下的金额 (输出第一个符合条件的即可) 三重循环
#include <stdio.h>
int main()
{
int x;
int one ,two,five;
int exit=;
scanf("%d",&x);
for (one=;one<x;one++){
for (two=;two<x/;two++){
for(five=;five<x/;five++){
if(one+*two+five*==x){
printf("用%d个一元 %d个两元 %d个五元得到%d元\n",
one,two,five,x);
exit=;
break; //只能结束当前循环,如何跳出三个循环 ?增加exit变量 接力break
}
}
if (exit==)break;
}
if (exit==)break;
}
}
23
用1个一元 6个两元 2个五元得到23元
//上述称为接力break, 还有一种方法 用goto, 可以免去写很多个break
#include <stdio.h>
int main()
{
int x;
int one,two,five; scanf("%d",&x);
for (one=;one<x;one++)
{
for (two=;two<x/;two++)
{
for(five=;five<x/;five++){
if(one+*two+five*==x){
goto out; //后面定out的位置
}
}
} }
out:
printf("用%d个一元%d个两元 %d个五元得到%d元\n",one,two,five,x);
}
12
用1个一元3个两元 1个五元得到12元
//求和 1+1/2+1/3+1/4...+1/n
#include <stdio.h>
int main()
{
int n;
int i;
double sum=0.0;
scanf("%d",&n);
for(i=;i<=n;i++){
sum+=1.0/i;
}
printf("f(%d)=%f\n",n,sum) ;
}
10
f(10)=2.928968
//求和 1-1/2+1/3-1/4...+(-1)^(n-1)*1/n, 增加sign符号
#include <stdio.h>
int main()
{
int n;
int i;
int sign=;
double sum=0.0;
scanf("%d",&n);
for(i=;i<=n;i++){
sum+=sign*1.0/i;
sign=-sign;
}
printf("f(%d)=%f\n",n,sum) ;
}
4
f(4)=0.583333
//求两个数的最大公约数
方法1: 先找到两数的较小者min , 循环 i=1:min找公因子, 循环结束得到的就是最后一个(最大公因数)
#include <stdio.h>
int main()
{
int a,b;
int min ;
scanf("%d %d",&a,&b);
if (a<b){
min=a;
} else{
min=b;
}
int ret=;
int i;
for(i=;i<min;i++){
if (a%i== && b%i==){
ret=i;
}
}
printf("%d and %d 的最大公约数是%d",a,b,ret);
}
10 25
10 and 25 的最大公约数是5
//方法2: 辗转相除法 a=12, b=18 ,t记录a%b 然后a=b, b=t, 继续做下去
思路:
// a b t
//12 18 12
//18 12 6
//12 6 0
//6 0 b是0的时候结束, 此时a是最小公约数
#include <stdio.h>
int main()
{
int a,b;
int t;
scanf("%d %d",&a,&b) ;
while(b!=){
t=a%b;
a=b;
b=t;
}
printf("gcd=%d\n",a);
}
//正序分解整数 12345 输出 1 2 3 4 5
//先回顾逆序输出... x%10 得到最后一个数字. x/10去掉最后一个数
#include <stdio.h>
int main()
{
int x;
scanf("%d",&x);
//x=12345;
do{
int d=x%; //得到个数数字
printf("%d ",d);
x/=;
} while(x>);
}
1200
0 0 2 1
// 正序可以通过逆序两次得到
#include <stdio.h>
int main()
{
int x;
int t=;
scanf("%d",&x);
//x=12345;
do{
int d=x%; //得到个数数字
t=t*+d;
x/=;
} while(x>);
printf("t=%d\n",t);
x=t;
do{
int d=x%; //得到个数数字
printf("%d ",d);
x/=;
} while(x>);
}
1329
t=9231
1 3 2 9
但是输入600 得到的 t=6 最后结果也是6 不是 006,修改思路如下
// 思路 : x=1234
//1234/1000 1 ..
//1234%1000 234
//1000/10 100
//234/100 2. ..
//234%100 34
//100/10 10
//34/10 3. ..
//34%10 4
//10/10 1
//4/1 4 ...
//4%1 0
//1/10 0
#include <stdio.h>
#include<math.h>
int main()
{
int x;
scanf("%d",&x);
int t=x;
int cnt=; //计算位数
do{
x/=;
cnt++;
} while(x>);
printf("%d\n",cnt);
int m=pow(,cnt-);// pow没有定义?? 增加#include<math.h>
printf("%d\n",m);
x=t;
do{
int d=x/m;
printf("%d ",d);
x%=m;
m/=;
}while(m>);
}
123
3
100
1 2 3
上述没必要用pow求
#include <stdio.h>
#include<math.h>
int main()
{
int x;
scanf("%d",&x);
int m=;
int t=x;
while(x>){
x/=;
m*=;
} x=t;
do{
int d=x/m;
printf("%d ",d);
x%=m;
m/=;
}while(m>);
}
小学生都看得懂的C语言入门(2): 判别 循环的一些应用实例的更多相关文章
- 小学生都看得懂的C语言入门(1): 基础/判别/循环
c基础入门, 小学生也可以都看得懂!!!! 安装一个编译器, 这方面我不太懂, 安装了DEV-C++ ,体积不大,30M左右吧, 感觉挺好用,初学者够了. 介绍下DEV 的快键键: 恢复 Ctrl+ ...
- 小学生都看得懂的C语言入门(5): 指针
现在已经学到C语言的后面了, 快学完咯.... (一)取地址运算 先来看一下sizeof 计算所占字节 #include<stdio.h> int main() { int a; a=; ...
- 小学生都看得懂的C语言入门(6): 字符串
1.字符用 char 表示 #include<stdio.h> int main() { char c; char d; c=; d='; if (c==d){ printf(" ...
- 小学生都看得懂的C语言入门(4): 数组与函数
// 之前判断素数, 只需要到sqrt(x)即可,//更加简单的, 判断能够比已知的小于x的素数整除, 运行更快 #include <stdio.h> // 之前判断素数, 只需要到sqr ...
- 小学生都看得懂的C语言入门(3): 数组与函数
#include <stdio.h> int main() { int x; ; ; scanf("%d",&x){ sum+=x; cnt++; scanf( ...
- 小学生都能读懂的网络协议之:WebSocket
目录 简介 webSocket vs HTTP HTTP upgrade header websocket的优点 webScoket的应用 websocket的握手流程 WebSocket API 总 ...
- 胖虎都看得懂的CSS入门
CSS入门 CSS是什么 摘自维基百科 层叠样式表(英语:Cascading Style Sheets,简写CSS),又称串样式列表.级联样式表.串接样式表.层叠样式表.階層式樣式表,一种用来为结构化 ...
- 小白都看得懂的Javadoc上手教程
Javadoc是什么 官方回答: Javadoc is a tool for generating API documentation in HTML format from doc comments ...
- 小白都看得懂的Javadoc使用教程
Javadoc是什么 官方回答: Javadoc is a tool for generating API documentation in HTML format from doc comments ...
随机推荐
- Vue.js 技术揭秘(学习) 深入响应式原理 nextTick外传
microTask mutationObserve. promise.then macroTask setImmediate. messageChannnel.setTimeout.postMess ...
- vue-CLI踩坑记
vue init webpack vue-demo 使用 windows 7 DOS命令行和gitbash都有选择和实际选择结果不一致的问题, DOS命令行只在 Vue build有问题, gitba ...
- D. Time to go back(思维)
题目链接:http://codeforces.com/gym/100952/problem/D 题目大意:n个礼物,m个人,要给m个人中的k个人买大于等于d的礼物,其他人随意,问你选择礼物的方案数(不 ...
- 《jQuery精品教程视频》-每天的复习笔记
第一天 //jquery:简单.粗暴 //jq和js的关系 //js是什么? js是一门编程语言 //jq仅仅是基于js的一个库,jq可理解为就是开发js的一个工具. //概念 //1. 为什么要学j ...
- Javascript - ExtJs - 常用方法和属性
常用方法和属性(Common methods and attributes) ExtJs中的对象 Ext.Component Ext组件对象,表示一个可渲染的组件. Ext.dom.Element E ...
- Photoshop CS6打开图片后看不到怎么办
https://jingyan.baidu.com/album/54b6b9c0d45c632d583b4793.html
- Netty实现简单私有协议
本文参考<Netty权威指南> 私有协议实现的功能: 1.基于Netty的NIO通信框架,提供高性能异步通信能力 2.提供消息的编码解码框架,实现POJO的序列化和反序列化 3.提供基于I ...
- UML类图表达
什么是UML类图? 类图显示了一组类.接口.协作以及他们之间的关系.在UML中问题域最终要被逐步转化,通过类来建模,通过编程语言构建这些类从而实现系统.类加上他们之间的关系就构成了类图,类图中还可以包 ...
- Switch 中参数的范围探讨
switch 语句必须遵循下面的规则: switch 语句中的 expression 必须是一个整型或枚举类型,或者是一个 class 类型,其中 class 有一个单一的转换函数将其转换为整型或枚举 ...
- 题解-PKUWC2018 Minimax
Problem loj2537 Solution pkuwc2018最水的一题,要死要活调了一个多小时(1h59min) 我写这题不是因为它有多好,而是为了保持pkuwc2018的队形,与这题类似的有 ...