(我是初学者)练习中的问题

问题:300个人围成一个圈,从某个指定的人开始报数(1--3),凡是数到3的人退出圈子,问最后剩下的一个是从指定位置开始计数的第几个人?

我先来说说我的思路,做为一个初学者,思维还停留在数学方法上,首先想到的是建立一个数组,但是怎么把他们变成一个圆是一个难点。

首先下标凡是(i+1)%3=0的,都把值赋为1,同时计数器count加1,这是第一轮。

第二轮,因为上一轮在最后一个报3的人后,可能还有1/2人报数,所以这轮是把上轮留下的人数b+i来对3求余(b+i+1)%3=0的赋值为1。想到这,问题来了,如果碰到上一轮退出的也就是值为1的不报数,所以我们要在(b+i+1)中减去,这样就要去定义一个计数器来对此计数·····

这样一边写,一边想,一边到前面去补变量,补相应的代码,写出来的程序长不说,一旦哪个地方没想好,就得回去改,还得在草稿上算相应的数字,非常麻烦。

而老师是样的呢?

   同样是用数组a(初始值为0),另外定义了3个变量,i数组下标,count计数器计算退出的人数,n报数(123)。

  然后开始循环count<299,i++并且n++,if(n=3&&a[i]=0),数组项=1,并且n=1。否则i++且n--。最经典的地方就是,if(i=alength-1)时i=0,这样就直接开始了第二次循环,把一个直线变成了一个圆。

 

我们经常惊讶老师的代码简洁,思路新奇,我们没有想到,其实就目前来说,我们只要能做出最后的结果,不是瞎蒙而是自己的思路,能做出最后的结果就行,在做好后,拓展想一想,哪些步骤可以合并,哪些步骤可以用别的方法来完成。老师的代码方式,在遇到什么问题的时候可以使用同样的思维方式,时间长了,积累足了,就能写出较高质量的代码了。

posted @ 2017-04-16 02:19  流星逝  阅读(85)  评论(0编辑  收藏  举报