爱看读书 通过搜索各大小说站为您自动抓取各类小说的最快更新供您阅读!

谢维康突然一拍桌子,喝道:“有了!”

这一嗓子把小哥惊得一个激灵,他忍不住骂道:“别一惊一乍的,吓我一大跳!快说,你想到什么办法了?”

谢维康指着屏幕上的迷宫,说道:“你仔细看,你这些迷宫,周围是不是都围着一圈墙?”

小哥紧盯着屏幕,目光跟着谢维康的手指移动,顺着他的话细细思索。

谢维康的手在屏幕上滑动,继续分析道:“你看,这圈墙后面是路,路后面又是墙。也就是说,在这个二维平面里,垂直方向第一列是墙、第二列是路、第三列是墙、第四列是路,以此类推,奇数列是墙,偶数列是路。水平方向也是一样,没错吧?”

小哥领会过来,轻轻点了点头。

“而且你的起点和终点,都开在这最外圈的墙上,中间的路也连通着墙。”谢维康接着说道,“我有个想法,你听听行不行?”

见谢维康停了下来,还直盯着自己,小哥急道:“你快说啊,别卖关子了,我都快愁死了!”

谢维康解释道:“首先,这些地图的宽度和高度必须是奇数行、奇数列。你先生成一圈墙,再定好入口和出口,接着从入口开始生成路。用0、1、2、3四个数字表示前进方向,每次往前走两步就生成一个节点,做好标记,再用随机数确定下一步方向。这样一来,这些节点就是迷宫里的路。要是当前方向的下一个节点已经有标记,说明这条路走不通,得转弯;要是前进方向的前、左、右三个方向都有标记,那就是死路。之后你扫描整个地图数据,找到未标记的节点,这个节点周围四个节点里,肯定有一个是已标记的。从这个已标记节点开始,往未标记节点继续重复上面的流程,直到扫描完整个地图、找不到未标记节点为止。这些连在一起的节点就是迷宫的路,剩下的就都是墙。最后根据这些数据把迷宫画出来就行。”

小哥的眉头皱得更紧,显然还没完全听明白。

谢维康见状,到吧台借了纸笔,在纸上随便画了个小迷宫,一边在里面画线,一边接着解释。

最后他总结道:“我的意思是,你别管墙不墙的,就当地图上有隐形的墙,奇数行列上的点全是墙。你要做的,就是模拟从入口到出口的过程,遍历整个地图,能穿透这些隐形的墙,找出所有能走的路。既然所有能走的路都找到了,剩下的不就全是墙了吗?”

这番解释让小哥豁然开朗,他一边点头一边重复并总结谢维康说的方法:“哦,我懂了!你是说从入口开始找路,遇到死路就回头换条路,一直找,直到把全地图的路都找出来,对不对?”

谢维康松了口气,总算能顺着这个话茬往下说。

可小哥又冒出新问题:“那怎么确保这条路能和出口连上呢?”

“首先,你设置入口和出口时,它们的行号或列号必须是偶数。”谢维康解释道,“这样一来,入口和出口肯定能和路的节点连上,两者之间至少会有一条通路。至于会不会有第二条通路,我就不确定了,毕竟我没写过这么复杂的逻辑。”

说到这儿,他故作深沉地纠正道:“哦对了,我刚才有个地方说错了。c语言的数组下标是从0开始的,所以奇数行列对应的数组下标其实是偶数。”

小哥当即给谢维康竖了个大拇指:“嚯,原来可以通过搜索路来确定迷宫数据呐?我之前一直死磕迷宫的墙,你说,我怎么就没想到这个方法呢?刚刚听你这么一分析,我现在是茅塞顿开!”

话音刚落,他就不管谢维康,自己埋头忙活起来。

谢维康看了看时间,已经不早了,他点开qq,李梅还是没回复消息。

虽说他一直告诉自己,已经把对李梅的感情压在心底,可此刻还是忍不住露出一丝失落。

他利索地收拾好物品,关掉电脑,跟小哥道别后,离开网吧回了家。

……

翌日下午收工后,谢维康又去了网吧,刚在电脑上开始下载安装Vc++6.0,就有人从后面拍了拍他的肩膀。

他转头一看,正是昨晚遇到的那个小哥。

小哥拍着他的肩膀,笑容灿烂地夸道:“兄弟,你可真有两下子!昨天你走后,我按你说的方法写了段代码,居然真成了,我给你看看……”

说着,小哥打开谢维康右边的电脑,往主机上插了个小东西,接着在“我的电脑”里点开一个文件夹,没一会儿就把Vc++6.0装好了。

谢维康疑惑地问:“你插在电脑上的这是什么?怎么没见你下载,Vc++6.0就装上了?”

小哥一边摆弄电脑,一边回答说:“哦,你说这个啊,这是U盘,用来存数据的。”

谢维康觉得这东西不错,又追问道:“多少钱一个?”

“我这个是128mb的,花288元买的。”小哥解释说。

谢维康惊呼道:“啥?288元?这么贵?”

小哥看了他一眼,继续说道:“我买得早,现在256mb的差不多也就这个价。”

可这个价格还是让谢维康吓了一跳,就这么个小玩意儿,得他在装修工地上辛辛苦苦干八九天活才能买到。他暂时打消了买U盘的念头。

小哥装好Vc++6.0后,打开自己写的代码,指着屏幕说道:“你看,这就是我写的代码。按你说的思路写完后,只要在右键菜单里执行一个命令,一秒钟就能生成一个迷宫,感觉比我自己画的还合理。”

说着,他按下F5,屏幕上弹出一个窗口。他熟练地操作着界面,点了几下后,右键调出菜单,搓着手对谢维康说道:“来了哟,兄弟,见证奇迹的时刻到了,你看……”

话音未落,他用鼠标点了一下菜单里的命令。不到一秒钟,屏幕上就出现了一个和他之前画的差不多的迷宫。

小哥激动地喊道:“兄弟,我太爱你了!”

说着就要往谢维康身上扑,谢维康赶紧拦住他,用力推开,抱怨道:“哎哎哎!你干什么?两个大男人在公共场合搂搂抱抱的,像话吗?跟你说,我是有女朋友的,不搞基!你这一激动,我差点‘贞洁不保’了!”

小哥没把他的抱怨当回事,伸出手自我介绍道:“兄弟,我叫段雷,是成都理科大学的学生。还没请教你的尊姓大名?”

谢维康伸手和他握了握,介绍道:“我叫谢维康,已经没上学了。”

段雷疑惑地问道:“没上学了?那你编程技术怎么这么好?”

谢维康心里满是委屈,自己就随便跟他聊了几句,怎么就帮他把这么个难题解决了呢?这也太不科学了。

但他嘴上还是谦虚地说道:“哪里哪里,我就是随口一说,一行代码都没写,这都是你自己写出来的。”

段雷却伸出食指摆了摆,解释道:“不不不,你说得不对,你虽然没帮我写一句代码,但你给我的算法让我豁然开朗,要是没有你提供的这个算法,我也没法这么快解决这个问题,所以你功不可没。”

谢维康反问道:“算法?什么是算法?”

段雷看着他,不知道这家伙是真不懂还是装糊涂,疑惑地问道:“你不知道什么叫算法?”

谢维康茫然地摇了摇头。

段雷拍了拍自己的额头,虽然无奈,但还是耐心地解释道:“学编程,本质上是培养逻辑思维,总结出算法,最后把算法转换成代码。”

谢维康还是一脸茫然,显然没听懂这句话。

段雷见状,换了个方式问道:“我问你个问题,要是让你算5和3的和等于多少,你会想到什么办法?”

谢维康脱口而出说道:“这简单啊,把5和3加在一起就行了!”

“没错。”段雷说,“我们的问题是算5和3的和,你说的‘把5和3加在一起’,用语言描述出来的这个方法就是算法。接下来,我们写下‘5+3=8’这个算式,这就相当于是代码。”

谢维康似乎懂了些,点了点头,低头琢磨起来。

段雷继续说道:“小学时我们经常做应用题,比如‘一个施工队修公路,5天修了全程的25%,问修完这条路需要多少天’,这种题你做过吧?”

谢维康点头道:“当然做过,还做了不少。”

“那你当时是怎么做的?”段雷问。

谢维康回忆道:“我记得老师教过一个方法,画一条线段,在大约25%的位置画个点,上面写天数,下面写百分比,然后用天数除以对应的百分比,就能算出修完全程需要的天数。”

“看来你们老师教得不错。”段雷说,“他让你画的线段图,也是一种算法。根据这个线段图,最后得出‘用天数除以对应百分比,得到全程天数’的结论,把这个结论对应的过程用代码语句写出来,就是程序。简单说,遇到问题时,别先想着写代码,要先想怎么解决问题,不管是用语言描述,还是画图,这些解决方法都是编程里的算法。”

谢维康这下彻底豁然开朗,笑着对段雷说道:“哦,你说得有道理!没错,得先把算法描述出来,才能写出代码,就是这么回事!”

接着,他指着段雷的代码问道:“哎,你这个数组怎么这么奇怪?下标后面怎么还有个点?后面的data是什么意思?”

段雷用看“白痴”的眼神看着他,不解地问道:“这是结构体啊,你连这个都不会?”

谢维康挠了挠头道:“结构体?我觉得这东西没用,就没当回事。”

“你可拉倒吧!”段雷不屑地说,“结构体这么有用的东西,你居然说没用?”

“那你这么写,有什么意义啊?”谢维康追问。

段雷解释道:“你昨天不是自己说的吗?用一个标记记录节点状态。这个index就是标记,data是地图数据,map是结构体的变量名。”

谢维康又有了新疑惑,问道:“那我直接定义一个数组存地图数据,再用一个数组存标记,不也一样吗?”

“一点都不一样。”段雷继续解释道,“你看,我这个结构体有index和data两个成员,说明它有两种属性。我把它定义成map的类型,那每个map就都有这两种属性。就像一个人,同时有姓名、性别、年龄、身高、体重这些属性。每个结构体变量就好比一个人,提取信息时,能一次性拿到他的姓名、性别、年龄这些所有属性。而且传递参数时,只要传一个结构体变量名,函数就能获取这个结构体的所有属性。当然,一般情况下我们不直接传结构体本身,而是传它的指针。”

谢维康恍然大悟:“哦,原来是这样!我懂了。看来你这种科班出身的,和我这种‘野生’学编程的,确实不一样。”

段雷毫不避讳地说道:“那当然!你学编程花了多少钱?我妈供我上大学,每年光学费就五千多,还不算生活费。”

谢维康点头表示理解:“也是,我要说花钱,也就买了两本编程书而已。”

弄明白结构体的意义后,谢维康又冒出新问题,继续问道:“我刚刚听你说了‘指针’,不知道这‘指针’又是什么东西?”

段雷盯着谢维康看了足足十秒,谢维康下意识摸了摸自己的脸,还以为脸上沾了什么脏东西。

最后,段雷没好气地说道:“你的问题也太多了,自己看书去!”

说完,他转头自顾自写代码去了。

谢维康撇了撇嘴,倒也接受了这个建议,自嘲道:“看来书还是看得不够仔细,也是,大师写的教材里,肯定没多少没用的知识点,以后看书得更认真,一点都不能跳过。”

接着,他转向段雷,提议道:“段大哥,咱们能不能加个qq好友?以后我要是有问题,还能问你。”

段雷爽快地答应道:“哦对,加个qq!别的不说,你有问题我肯定帮你。”

谢维康拍了拍他的肩膀,调侃道:“那以后你可别嫌我烦啊。”

段雷也拍了拍他的肩膀,爽快的应道:“没问题,以后哥罩着你!”

说完,两人都哈哈大笑起来。

之后,谢维康把结构体那一章重新学了一遍,还自己写了些代码练习,巩固知识点。

眼看时间不早了,他又看了眼qq,李梅依旧没有任何回复。

谢维康跟段雷道别后,便回家了。

爱看读书推荐阅读:汴京小食堂Dan与落下遇见你,何其幸运潇洒小道士万界神豪:咸鱼倒卖记救驾女帝被流放,爆兵成皇你哭什么?被系统砸脸后,我与钟离互换身体崩坏三:【我的系统有问题】快穿:把冷情佛子诱拐回家李青踏上修真途重生怒甩前夫,给崽亲父王腾位置我是魔法学院柔弱的白月光学妹黑化后,小叔叔被我虐到心碎斗罗V:开局被千仞雪看上,小舞要贴贴佛系大小姐穿越古代悠闲生活快穿之好男人修炼指南奥特大剪辑:盘点光之国裂开了!嫁妖夫,算了,凑合过吧重回七零,嫁给科研大佬生三宝学法律的算命大佬,很常见吧?我下山娶妻,清冷师尊失控了天降崽子!霸总追妻带娃弃后她在现代活成顶流我在崩坏转生成芽衣弃妇掉马后,怒打渣男脸!疯批帝姬嫁给摄政王后雄起了魔瞳修罗穿越星际,我娶了帝国最强o斗罗:重生教皇,多子多福穿越火影陪四代目长大恋爱脑醒悟,我竟成了总裁夫人!白月光身份曝光,禁欲祁总跪碎膝盖断亲单开族谱,柔弱表小姐不好欺小财迷只想躺平,霍少的摆烂甜妻异世:没灵气咋修真快穿之我在狗血虐文当女主网球王子:龙马的姐姐在冰帝睡前故事嗯哼!我家超市通三千位面重生之冷面王爷的娇俏王妃穿越到星际成神彼岸花与雪莲花灵魂摆渡:我师傅是九叔灵气复苏别逞强,我是外挂贩卖郎!末世屯物资摆脱圣母诅咒婚女重生自救指南快穿:所有人都爱绿茶美人凹凸世界之与美好失之交臂让你去挖矿,你却成了夜之城的王总裁,有四个萌娃说是您家崽儿
爱看读书搜藏榜:勇者队伍里的普通人穿越成废柴,驭万兽,瞳术定乾坤九转归幽地狱病院咒术回战:我成了五条悟的姐姐浅风不及你情深次元:我只是一个路过的赛亚人!骑士君的非凡之路诸天影视莽夫开局欢乐颂开局大宗门,我却意外成了散修太子妃手握空间踏仙路觉醒变异植物系,她在末世横行了毕业了好好爱照进深渊的月亮幽冥之契逆天,影后视后全是我不良人:悟性逆天,震惊不良帅述录说你私生子命贱,你带七个老婆造反?抗战雄鹰,开局就抢鬼子战斗机重生赶海文里,我是路人甲快穿年代:拿下病娇反派生崽崽啦人在娘胎,我邦邦给女帝两拳穿越魔法纪元之至尊女法皇禁墟迷城国运强不强,全看宴姐浪不浪!正道诛天诸天修行,从功夫开始爱在梦里等花开少年歌行之不染凡尘遥知殊途神罚圣域:铁子的武神之路离婚当天,慕小姐改嫁前夫死对头君乃天上客穿成妖族太子后,美人师尊日日宠三生瑾瑜四合院之成就非凡男人三十,成功逆袭重回身体后,靠着现代科技鲨疯了斗破:我可以加点修行快穿:一本爽文中的爽文你我,一别两宽穿越1960四合院钓鱼又打猎穿书七零,捡个便宜老公宠到底约战里的咸鱼修仙重生之太子妃她是京城首富重生九零好时光山河与你皆安好NBA:开局一张贾巴尔模板卡死对头他非要做我道侣
爱看读书最新小说:伏牛刘家修仙传我靠香艳误会,卷成天下第一修仙从修仙学院开始造物成仙永远长不大的孩子那只陪我长大的鬼灰烬中的薇光失业以后遇到鬼亲妈重生在七零,带着崽崽杀疯了穿越后我被祖师爷掰弯了昭昭煜煜那个比伏地魔还危险的人,回来了快穿:男主的外形,女作家的魂匿名下位圈:与总裁共攀巅峰四合院:这个院子有点不太正经难以开口的爱恋二嫁寡夫郎龙族:有精神疾病的我竟然是小龙我的灵尸女友是最终兵器穿越之我在山匪窝横行霸道春潮里[全职]再不败家就要被迫继承家业的我决定买下嘉世热血神魂柯南世界里的异人唐案奇录:法医娇娘与铁面县令斩劫者:九狱斩神录综漫:一把剑的旅途血棺惊语之旱妖降临寻仙赋长生四合院:说好的诸天却大多是杂院乱世医妃:带着空间改写历史穿书白月光,我成了女帝年代弹幕剧透:我家没一个好人凤舞朱阑火影:邪恶医师,他能改变性别!宇宙修真纪元海贼:我是帝江掌控空间盗墓,我成了老祖宗斗罗:混沌龙神与九心海棠皇快穿:大佬的婚后花样图鉴卷王和她的冤种追妻神星芒撞进夏日晚风始皇重生:朕归来斩奸臣追爱妻找谁说理?一米八帅哥穿成武大郎锦绣逆袭:从金牌保险顾问到将军奋进的青春退婚后与师姐同修觉醒纯阳神体槐下田舍平凡实习生与高冷霸总的意外恋曲恶女当家统统闪开