博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
历届试题 剪格子
阅读量:4331 次
发布时间:2019-06-06

本文共 1104 字,大约阅读时间需要 3 分钟。

 历届试题 剪格子  
时间限制:1.0s   内存限制:256.0MB
      
问题描述

如下图所示,3 x 3 的格子中填写了一些整数。

+--*--+--+

|10* 1|52|

+--****--+

|20|30* 1|

*******--+

| 1| 2| 3|

+--+--+--+

我们沿着图中的星号线剪开,得到两个部分,每个部分的数字和都是60。

本题的要求就是请你编程判定:对给定的m x n 的格子中的整数,是否可以分割为两个部分,使得这两个区域的数字和相等。

如果存在多种解答,请输出包含左上角格子的那个区域包含的格子的最小数目。

如果无法分割,则输出 0。

输入格式

程序先读入两个整数 m n 用空格分割 (m,n<10)。

表示表格的宽度和高度。

接下来是n行,每行m个正整数,用空格分开。每个整数不大于10000。

输出格式
输出一个整数,表示在所有解中,包含左上角的分割区可能包含的最小的格子数目。
样例输入1
3 3

10 1 52

20 30 1

1 2 3
样例输出1
3
样例输入2
4 3

1 1 1 1

1 30 80 2

1 1 1 100
样例输出2
10
 
真坑啊,忽略了是先输入列数再输入行数,另外后台测试数据太水了。
#include 
#include
#include
#include
#include
#include
#include
#define FOR(i,x,n) for(long i=x;i
q;int dfs(){ while(!q.empty()){ node t=q.front();q.pop(); FOR(i,0,4){ node next=t; next.x+=dirX[i];next.y+=dirY[i]; next.pathCounter++; next.sum+=a[next.x][next.y]; if(next.sum==half&&next.jud[next.x][next.y]==0){ ans=next.pathCounter; return 1; } if(next.jud[next.x][next.y]==0&&next.x>=0&&next.x
=0&&next.y

 

转载于:https://www.cnblogs.com/TWS-YIFEI/p/6440033.html

你可能感兴趣的文章
小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_2-4.后端项目分层分包及资源文件处理...
查看>>
小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_2-2.快速搭建SpringBoot项目,采用IDEA...
查看>>
小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_3-5.PageHelper分页插件使用
查看>>
小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_5-6.微信扫码登录回调本地域名映射工具Ngrock...
查看>>
小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_5-8.用户模块开发之保存微信用户信息...
查看>>
代码片段收集
查看>>
vue-cli3创建项目时报错
查看>>
输入1-53周,输出1-53周的开始时间和结束时间
查看>>
实验二
查看>>
shell——按指定列排序
查看>>
crash 收集
查看>>
507 LOJ 「LibreOJ NOI Round #1」接竹竿
查看>>
UI基础--烟花动画
查看>>
2018. 2.4 Java中集合嵌套集合的练习
查看>>
精通ASP.NET Web程序测试
查看>>
vue 根据不同属性 设置背景
查看>>
51Nod1601 完全图的最小生成树计数 Trie Prufer编码
查看>>
Codeforces 1110D. Jongmah 动态规划
查看>>
android驱动在win10系统上安装的心酸历程
查看>>
优雅的程序员
查看>>