本来是按照网上一个例子写的,但写出来后,未能达到效果,所以改动了其中一些方法。
1、上代码
以上是未改动的,以下是有改动的:
即judge_a()改成了judge_a1(),judge_a()使用了递归,较复杂未能看懂,judge_a1()使用了新增的变量 INPUT2和PASSWORD2,可以说是增加空间复杂度来降低算法复杂度了。。
以下是judge_b()改成了judge_b1(),情形与上面相同:
不过这下看起来judge_b1()比judge_b()更复杂了,我的错。。
最后上脚本的启动部分:
2、梳理一下该脚本的脉络:
init_password() : 初始化随机生成一个四位数的“密码”
input(): 接收用户输入的一个四位数
judge(): 循环计算结果,直到输入与密码相同
judge_a1(): 计算数字对位置也对的结果,结果用变量A保存
judge_b1(): 计算排除了上一种情况后数字对的结果,结果用变量B保存
输出的结果形如:2A2B,看一下效果吧:
3、总结,大部分是抄的,所以谈不上原创,不过也有自己的东西,主要是学会了一些知识:
1)shell里的for循环,用法有好几种,这里用到两种:
1、for i in `seq i`(`seq i` 是生成从1到i的整数)
2、for i in {1..4} ({1..4} 你懂的)
2)expr命令里的substr方法:
X=`expr substr "$INPUT" $i 1`
参数:第一个是原字符串,第二个是开始截取的位置,第三个是截取的长度
e.g.: expr substr “abc” 2 1,结果为:b
注意:shell里面字符串下标的开始是1而不是0 !切记切记。。
-----博客处子秀,欢迎光临!