题目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;

}

}

相关推荐
智者知已应修善业3 分钟前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
JasmineX-131 分钟前
数据结构(笔记)——双向链表
c语言·数据结构·笔记·链表
.54842 分钟前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove1 小时前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊1 小时前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法
徐某人..2 小时前
基于i.MX6ULL平台的智能网关系统开发
arm开发·c++·单片机·qt·物联网·学习·arm
无敌秋2 小时前
# C++ 简单工厂模式实战指南
c++·简单工厂模式
code_pgf3 小时前
Octo 算法详解-开源通用机器人策略模型技术报告
算法·机器人·开源
cany10003 小时前
C++ -- 模板的声明和定义
开发语言·c++