-
Lesson 1 - 最简单的C程序
-
Lesson 2 - 打印输出
-
Lesson 3 - 循环打印
-
Lesson 4 - 判断奇偶
-
Lesson 5 - 从1加到100求和
-
Lesson 6 - 乘法表
-
Lesson 7 - 求100以内的最大素数
-
Lesson 8 - 1到100有多少个9
-
Lesson 9 - 整型转字符串
-
Lesson 10 - 约瑟夫环
-
Lesson 11 - 求两个坐标点之间的距离
-
Lesson 12 - 判断机器存储是否小尾端
-
Lesson 13 - 对不起,你的车今天限行
-
Lesson 14 - 判断地图上某点是否有出路
-
Lesson 15 - 统计一个数二进制表示中1的个数
-
Lesson 16 - 字符串拷贝
-
Lesson 17 - 统计单词个数
-
Lesson 18 - 实现 printf
-
Lesson 19 - 命令解释器
-
Lesson 20 - 预处理器实现
-
Lesson 21 - 词法分析器实现
-
Lesson 22 - 猜数游戏
-
Lesson 23 - 五子棋
-
Lesson 24 - 超链接分析器
-
Lesson 25 - cp命令实现
-
Lesson 26 - ELF文件头分析器实现
-
Lesson 27 - 简单流处理器实现和正则表达式
-
Lesson 28 - 数学计算器实现
-
Lesson 29 - 数学计算器实现more命令实现
-
Lesson 30 - sort命令实现
-
Lesson 31 - ls -l命令实现
-
Lesson 32 - Bash项目
-
Lesson 33 - 动态数组实现
-
Lesson 34 - 约瑟夫环问题
-
Lesson 35 - 表达式求值问题
-
Lesson 36 - 广度优先解决迷宫问题
-
Lesson 37 - 词频统计器
-
Lesson 38 - 堆排序问题
-
Lesson 39 - 构造符号表
-
Lesson 40 - MyDictionary项目
-
Lesson 41 - BSearch 实现
-
Lesson 42 - QSort 实现
-
Lesson 43 - 深度优先解决迷宫问题
-
Lesson 44 - KMP 算法实现
-
Lesson 45 - 最长公共子序列(LCS)问题
-
Lesson 46 - Dijkstra 算法
-
Lesson 47 - Huffman Coding 算法
-
Lesson 48 - 地图导航项目
Lesson 3 Count how many fingers do you have? 循环打印
代码
#include <stdio.h>
int main(void)
{
int counter;
printf("hello, NCCL!\n");
counter = 0;
while (counter < 10)
{
counter++;
printf("counter = %d\n", counter);
}
return 0;
}
copy
do-while 用法
#include <stdio.h>
int main(void)
{
int counter;
printf("hello, NCCL!\n");
counter = 0;
do
{
counter++;
printf("counter = %d\n", counter);
} while (counter < 10);
return 0;
}
copy
第3种写法
#include <stdio.h>
int main(void)
{
int counter;
printf("hello, NCCL!\n");
counter = 1;
while (counter <= 10)
{
printf("counter = %d\n", counter);
counter++;
}
return 0;
}
copy
知识点
- 局部变量
- 循环语句 while
- 关系运算符 <=, >=
- 自增加运算符 ++
- 比较表达式求值
课堂讨论
- 第1种和第2种写法,都能得到正确结果,哪种更好?为什么?
- 第3种写法,运行也正确,为什么说它是不好的写法?
- 把 counter++ 写到 printf 语句中,是否是好的写法?
- counter 的初值为什么不在定义时就赋值,写在循环外面有什么好处?
- 在 while 循环里面,可以定义变量吗? 变量名字可以重名吗?
课后练习
- 将这个程序改为倒着从10数到0,应该怎么改最好?
- 新增一个变量 sum,对从1加到10进行求和,打印出最后结果。
- 使用 do-while 结构,实现上面2个要求。
- 打印一个数字的个位,十位,百位... 直到最高位。
名人名言
- Ken Thompson (Unix 之父)
- “When in doubt, use brute force. ”
- “如果局部变量太多,我倾向于拆分子程序。 另一个办法是看代码行是否存在太多缩进,我几乎从来不看代码长度。”