原题链接:蓝桥杯2013年第四届真题-剪格子
import java.util.Scanner; public class Main { private static int m, n, ans = Integer.MAX_VALUE; private static int nums; private static int[][] dis, Grid; private static int[] dx = { 1, 0, -1, 0 }, dy = { 0, -1, 0, 1 }; public static void main(String[] args) { Scanner sc = new Scanner(System.in); m = sc.nextInt(); n = sc.nextInt(); Grid = new int[n][m]; nums = 0; dis = new int[n][m]; for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { Grid[i][j] = sc.nextInt(); nums += Grid[i][j]; } } CutGrid(0, 0, 0, 0); System.out.println(ans); } public static void CutGrid(int x, int y, int cut, int steap) { if (cut == nums / 2) { ans = Math.min(ans, steap); return; } if (cut > nums / 2) { return; } dis[x][y] = -1; //标记已访问 cut += Grid[x][y]; //累加 for (int i = 0; i < dx.length; i++) { int tx = x + dx[i]; int ty = y + dy[i]; if (tx >= 0 && tx < n && ty >= 0 && ty < m && dis[tx][ty] == 0) { CutGrid(tx, ty, cut, steap + 1); dis[tx][ty] = 0; } } } }
解题思路:
注意事项:
参考代码:
0.0分
2 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复