今日收获------遍历+条件判断
📚题目
有 1、2、3、4 四个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
🧠思路分析
- 要能计数,也就是统计,来个count,放在遍历里面
- 同时也要打印,二者要放在一起
- 另外,有条件约束,我们用 if 语句进行选择性打印和选择性计数
🚀精选答案
c
#include "stdio.h"
int main ()
{
// 定义百位、十位、个位变量
int hundred, decade, unit;
// 统计无重复组合的数量
int count = 0;
// 遍历百位(1-4)
for (hundred = 1; hundred <= 4; hundred++) {
// 遍历十位(1-4)
for (decade = 1; decade <= 4; decade++) {
// 遍历个位(1-4)
for (unit = 1; unit <= 4; unit++) {
// 过滤掉有重复数字的组合
if (hundred != decade && hundred != unit && decade != unit) {
// 数字间加空格,输出更易读:如 1 2 3 而非 123
printf("%d %d %d\n", hundred, decade, unit);
count++;
}
}
}
}
// 输出总数
printf("Total combinations: %d\n", count);
return 0;
}
🤕我的试错之旅
for嵌套逻辑
一开始我是用的三层for循环,结果相当惨,而且我也百思不得其解
后来在co-pilot的帮助下理解了for循环的嵌套逻辑
------⚠️假定外层循环和内层循环都是三次,
------⚠️在第一轮大循环(外层for循环)中,内部循环(第二层和第三层)要全部跑完,再能进行下面两轮大循环(剩下两个for外层)
如下👇
bash
Outer loop i = 1
Middle loop j = 1
Inner loop k = 1
Inner loop k = 2
Middle loop j = 2
Inner loop k = 1
Inner loop k = 2
Outer loop i = 2
Middle loop j = 1
Inner loop k = 1
Inner loop k = 2
Middle loop j = 2
Inner loop k = 1
Inner loop k = 2
Outer loop i = 3
Middle loop j = 1
Inner loop k = 1
Inner loop k = 2
Middle loop j = 2
Inner loop k = 1
Inner loop k = 2
为什么在for里面做条件约束不行?🤔
很简单,因为for循环的条件判断,从外开始,而当我们的条件判断一旦不满足,直接进入下一轮大循环,上一轮满足条件的小循环就被忽略,所以最后会少很多结果
意料之外的错误------编译器格式规范➕变量初始化
自己写的时候,所有变量都没有初始化,结果最后TOATAL统计量count最后呈现混乱的栈溢出?但是上面的三位数变量分别都想安无事
😅另外就是这个奇葩的报错,因为我认为for,if后面就一个语句所以没有加花括号{}------这是我在嵌入式编程KEIL里面的习惯
bash
...
431
432
Total=-288981856
PS H:\Z_Desktop\TEST_CODE\C_TEST\vs code> cd "h:\Z_Desktop\TEST_CODE\C_TEST\vs code\" ; if ($?) { gcc tempCodeRunnerFile.c -o tempCodeRunnerFile } ; if ($?) { .\tempCodeRunnerFile }
tempCodeRunnerFile.c:1:1: error: expected '=', ',', ';', 'asm' or '__attribute_
' at end of input
1 | ation
| ^~~~~
解决方案🔍
- 对count变量进行初始化,count =0;
- 而🤔那三个变量却没事,是因为在for循环里完成了初始化 for(unit=1;unit<5;unit++)
- 还有就是无论怎样,都要加上花括号啊,保持格式严谨(不同编译器,严苛程度不同)
💬总结碎碎念
今天算是第一天,发现自己啥也不会,也算是敲响一个警钟吧😮💨
另外,🤔做这种纯软的题目,真的有用吗?因为本人并非CS专业
今天只是入门,以后可能会涉及到算法之类的东西吧