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

}

}

相关推荐
载数而行52015 小时前
QT的五类布局
c++·qt·学习
故事和你9115 小时前
sdut-程序设计基础Ⅰ-实验五一维数组(8-13)
开发语言·数据结构·c++·算法·蓝桥杯·图论·类和对象
载数而行52015 小时前
QT的QString类
c++·qt·学习
像污秽一样15 小时前
算法与设计与分析-习题4.2
算法·排序算法·深度优先·dfs·bfs
Storynone16 小时前
【Day20】LeetCode:39. 组合总和,40. 组合总和II,131. 分割回文串
python·算法·leetcode
bu_shuo16 小时前
Visual C++2010学习版(全国计算机等级二级考试版)安装记录
c++·cpp·visual c++·计算机二级
明明如月学长17 小时前
AI 更新太快学不过来?我用OpenClaw打造专属AI学习工作流
算法
黎阳之光17 小时前
【黎阳之光:以无线专网与视频孪生,赋能智慧广电与数字中国】
算法·安全·智慧城市·数字孪生
刀法如飞18 小时前
Agentic AI时代,程序员必备的算法思想指南
人工智能·算法·agent
刀法如飞18 小时前
Agentic AI时代程序员必备算法思想详解(附实战案例)
算法·ai编程·编程开发·agentic