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

#include<iostream>

#include<algorithm>

using namespace std;

int n,m;

int maze1010;

int vis1010;

int dx4={1,0,-1,0};//左右移动

int dy4={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+dxi;

int py=y+dyi;

if(vispxpy==0&&px>=0&&px<n&&py>=0&&py<m){

vispxpy=1;

dfs(px,py,total+mazepxpy,step+1);

vispxpy=0;//回溯

}

}

}

int main(){

cin>>m>>n;

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

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

cin>>mazeij;

sum+=mazeij;

}

}

vis00=1;

dfs(0,0,maze00,1);

if(ans!=100){

cout<<ans<<endl;

}

}

相关推荐
小蒋学算法11 分钟前
算法-乘法表中第K小的数-二分
数据结构·算法
智者知已应修善业20 分钟前
【51单片机8个LED,已经使用了D1D2,怎么样在不动D1D2的前提下实现D6~D8的流水灯】2024-1-19
c++·经验分享·笔记·算法·51单片机
Evand J21 分钟前
【MATLAB例程】自适应渐消扩展卡尔曼滤波(AFEKF)三维雷达目标跟踪|效果已调优,附下载链接和运行结果,代码直接运行即可
开发语言·算法·matlab·目标跟踪·卡尔曼滤波·自适应滤波·代码定制
坚果派·白晓明22 分钟前
鸿蒙PC适配实战:simdjson 三方库移植攻略与 AtomCode Skills 提效之道
c++·harmonyos·三方库·skills·atomcode·c/c++三方库·c/c++三方库适配
爱装代码的小瓶子23 分钟前
3. 设计buffer模块
linux·服务器·开发语言·c++·php
郝学胜-神的一滴23 分钟前
Qt 高级开发 027: QTabWidget自定义样式表美化实战
开发语言·c++·qt·程序人生·软件构建·用户界面
双河子思24 分钟前
《代码整洁之道》——读书笔记(持续更新)
开发语言·c++·c#
郝学胜-神的一滴1 小时前
Qt 高级开发 026:QTabWidget御道,从筑基到化境
开发语言·c++·qt·程序人生·软件构建·用户界面
插件开发1 小时前
矢量路径运算如何选GPU技术?——适用算法对比及OpenGL/Direct3D/CUDA选型指南
算法·3d
c++之路1 小时前
C/C++ 全链路编译工具汇总
c语言·开发语言·c++