C++试题求解,急!!!! 255

 我来答
610002858
2016-08-14 · TA获得超过286个赞
知道小有建树答主
回答量:77
采纳率:100%
帮助的人:39.9万
展开全部
我只想一想题解,具体写就算啦……
蒟蒻一只如果不幸搞错题解惹怒神犇勿喷=w=

首先审题发现步数显然是固定的,一个n*n的矩阵我们要走(n-1)*2步,然后我们经由左下-右上对角线把它划分为2个部分,对角线上的数字显然不用去管它因为你走的路是(n-1)个字符+中间字符+(n-1)个字符,对角线上的就是那个中间字符。

然后我们就可以愉快地开始bfs啦!

从(1,1)和(n,n)开始,分别向各自的小块开始bfs(就是把整张图变成一个上半个三角形和下半个三角形的图),走到一个格子把那个格子里的hash表里的元素增加相应的你这次走过的路径的hash值(这里需要开对应的数组来存,比如设ABChash值是k,那么你就把hash[1][3][k]++,当然需要离散化一下)。用来记录前面走过的格子(字符串hash会吧=w=),然后就类似折半搜索(自己取的名字,不是二分),两边走到中间格子的hash表的东西比一比,比如样例里D那个格子从(1,1)出发就有1种ABCD,2种ABED;从(n,n)出发也有1种ABCD,2种ABED;所以D这个格子的贡献就是1*1+2*2=5

应该就是这种做法。别忘了采纳哦=w=
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式