题目1432:蓝桥杯2013年第四届真题-剪格子

#include<iostream>

#include<algorithm>

using namespace std;

int n,m;

int maze[10][10];

int vis[10][10];

int dx[4]={1,0,-1,0};//左右移动

int dy[4]={0,1,0,-1};//上下移动

int sum=0,total=0;

int ans=100;

void dfs(int x,int y,int total,int step){//dfs+回溯

//终止条件1:现有总和满足总数一半

if(total==sum/2){

ans=min(ans,step);

return;

}

//终止条件2:现有总和超过总数一半

if(total>sum/2){

return;

}

for(int i=0;i<4;i++){

int px=x+dx[i];

int py=y+dy[i];

if(vis[px][py]==0&&px>=0&&px<n&&py>=0&&py<m){

vis[px][py]=1;

dfs(px,py,total+maze[px][py],step+1);

vis[px][py]=0;//回溯

}

}

}

int main(){

cin>>m>>n;

for(int i=0;i<n;i++){

for(int j=0;j<m;j++){

cin>>maze[i][j];

sum+=maze[i][j];

}

}

vis[0][0]=1;

dfs(0,0,maze[0][0],1);

if(ans!=100){

cout<<ans<<endl;

}

}

相关推荐
Brilliantwxx1 天前
【C++】 继承与多态(中)
开发语言·c++·笔记·算法
青瓦梦滋1 天前
C++的IO流与STL的空间配置器
开发语言·c++
鱼很腾apoc1 天前
【学习篇】第20期 超详解 C++ 多态:从语法规则到底层原理
java·c语言·开发语言·c++·学习·算法·青少年编程
不吃土豆的马铃薯1 天前
4.SGI STL 二级空间配置器 allocate 与_S_refill 源码解析
c语言·开发语言·c++·dreamweaver·内存池
小许同学记录成长1 天前
三维重建技术文档
算法·无人机
fufu03111 天前
vscode配置C/C++环境,用GDB调试简单程序分享
开发语言·c++
水云桐程序员2 天前
C++变量的概念及用法
开发语言·c++
小O的算法实验室2 天前
2026年ASOC,基于多目标优化去噪双存档进化算法+路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
水饺编程2 天前
第5章,[Win32 章节] :几种典型的颜色
c语言·c++·windows·visual studio