解题思路: 注意事项: 开头和结尾字符单独比较。 中间字符比较时,如果可以完成替换操作,则需执行替换,否则会对后续字符比较产生影响。 参考代码: ## 翻转 D=int(input()) string=[list(input()) for _ in range(2*D)] def Turn_string(string,D): dp=[0]*D for i in range(D): for j in range(1,len(string[2*i])-1): if string[2*i][j]!=string[2*i+1][j]: if string[2*i+1][j-1]==string[2*i+1][j+1]==string[2*i][j]: string[2*i+1][j]=string[2*i][j] dp[i]+=1 else: dp[i]=-1 break if string[2*i][0]==string[2*i+1][0] and string[2*i][-1]==string[2*i+1][-1]: continue else: dp[i]=-1 return dp dp=Turn_string(string,D) for i in range(D): print(dp[i])
0.0分
2 人评分
C语言程序设计教程(第三版)课后习题8.4 (Java代码)浏览:788 |
C语言程序设计教程(第三版)课后习题6.7 (C语言代码)浏览:674 |
C二级辅导-计负均正 (C语言代码)浏览:698 |
P1002 (C语言代码)浏览:1019 |
简单的a+b (C++语言代码)浏览:895 |
C语言程序设计教程(第三版)课后习题6.6 (C语言代码)浏览:366 |
C语言程序设计教程(第三版)课后习题6.8 (C语言代码)浏览:544 |
哥德巴赫曾猜测 (C语言代码)浏览:2560 |
C语言程序设计教程(第三版)课后习题8.7 (C语言代码)浏览:609 |
1128题解(返回值为数组的情况)浏览:571 |