当前位置: 首页 > news >正文

手机网站左右滑动效果wordpress 贴吧主题

手机网站左右滑动效果,wordpress 贴吧主题,软件技术前端开发,内容营销经典案例题目描述 小杨有一个 n 行 m 列的网格图,其中每个格子要么是白色,要么是黑色。 小杨想知道至少包含 k 个黑色格子的最小子矩形包含了多少个格子。 输入格式 第一行包含三个正整数 n,m,k,含义如题面所示。 之后 n 行,每行⼀个…

题目描述

小杨有一个 n 行 m 列的网格图,其中每个格子要么是白色,要么是黑色。

小杨想知道至少包含 k 个黑色格子的最小子矩形包含了多少个格子。

输入格式

第一行包含三个正整数 n,m,k,含义如题面所示。

之后 n 行,每行⼀个长度为 m 的 01 串,代表网格图第 i 行格子的颜色,如果为 0,则对应格子为白色,否则为黑色。

输出格式

输出一个整数,代表至少包含 k 个黑色格子的最小子矩形包含格子的数量,如果不存在则输出 0。

输入输出样例

输入 #1

4 5 5
00000
01111
00011
00011

输出 #1

6

说明/提示

样例解释

对于样例 1,假设 (i,j) 代表第 i 行第 j 列,至少包含 5 个黑色格子的最小子矩形的四个顶点为 (2,4),(2,5),(4,4),(4,5),共包含 6 个格子。

数据范围

对于全部数据,保证有 1≤n,m≤100,1≤k≤n×m。

子任务编号得分n,m
120≤10
240n=1,1≤m≤100
340≤100

做法一:暴力

#include <iostream>
using namespace std;int s[110][110];
int main()
{int n,m,k;cin>>n>>m>>k;for(int i=1;i<=n;i++)for(int j=1;j<=m;j++){char c;cin>>c;s[i][j]=s[i][j-1]+s[i-1][j]-s[i-1][j-1]+(c=='1');}int maxn=2e9;for(int r1=1;r1<=n;r1++)for(int r2=r1;r2<=n;r2++)for(int c1=1;c1<=m;c1++)for(int c2=c1;c2<=m;c2++){int area=(r2-r1+1)*(c2-c1+1);int b=s[r2][c2]-s[r1-1][c2]-s[r2][c1-1]+s[r1-1][c1-1];if(b>=k&&area<maxn)maxn=area;}cout<<(maxn<2e9?maxn:0);return 0;
}

搞一个二位前缀和暴力,打擂台,无了,但是O(n⁴),这道题数据小能过。

---------------------------------------------------------------------------------------------------------------------------------

做法二:二分 

#include <iostream>
using namespace std;int n,m,k,r1,r2,s[110][110];
int f(int a,int b,int c,int d)
{return s[b][d]-s[a-1][d]-s[b][c-1]+s[a-1][c-1];
}
bool check(int mid)
{for(int l=1;l+mid-1<=m;l++){int r=l+mid-1;int b=f(r1,r2,l,r);if(b>=k)return true;}return false;
}
int bs()
{int l=1,r=m;while(l<r){int mid=(l+r)/2;if(check(mid))r=mid;elsel=mid+1;}return l;
}
int main()
{cin>>n>>m>>k;for(int i=1;i<=n;i++)for(int j=1;j<=m;j++){char c;cin>>c;s[i][j]=s[i][j-1]+s[i-1][j]-s[i-1][j-1]+(c=='1');}int minx=2e9;for(r1=1;r1<=n;r1++)for(r2=r1;r2<=n;r2++){if(f(r1,r2,1,m)<k)continue;int w=bs();int area=(r2-r1+1)*w;if(area<minx)minx=area;}cout<<(minx==2e9?0:minx);return 0;
}

做法:

        1.二层循环固定r1和r2。

        2.二分查找,找宽度(即c1和c2差)。

        3.check里枚举所有可能,有一个满足就return true。

        4.二层循环*二分*check,复杂度O(n³logn)。

细节:

        1.写一个f函数算二维区间和,简洁还能偷懒o(* ̄▽ ̄*)ブ

        2.由于是二分,必须保证两头至少一个是true,不然会出错,所以要提前判断这个r1和r2的最大区间够不够k个,不够continue。

http://www.yayakq.cn/news/972921/

相关文章:

  • 做写手哪个网站好网站建设费是
  • 无锡门户网站制作电话用微魔方做的网站一定要加
  • 做网站好还是做安卓app好烟台建设协会网站
  • 购买域名后 可以做网站么重庆好的seo平台
  • 网站开发要学些什么网站开发与应用总结
  • html5 单页 响应式 网站模板申请一个网站需要怎么做
  • 免费做网站表白服务质量好的crm系统
  • 为什么小城市做不出来好的网站上海做网站 公司
  • 西安高端网站建设哪家好网站未做安全隐患检测怎么拿shell
  • 国外idc网站做国外wordpress賺钱
  • 邢台手机网站建设公司同时做几个网站互相链接
  • 天津哪里有做网站的wordpress瀑布流页面
  • 外国域名注册很多网站php网站配置说明
  • 网站建设常识一级消防工程师考试难不难
  • 优化网站排名解析推广学校网站建设目的是什么意思
  • 做网站框架番禺招聘网最新信息
  • 台州网站建设 网站制作 网站设计室内设计师工作内容
  • 营销型企业网站优化seo排名的影响因素有哪些
  • 个人网站备案网址wordpress php幻灯片代码
  • 做手机旅游网站百度站长如何添加网站
  • 怎样做网站卖手机号做电影网站怎么接广告
  • 如何建造网站西安传媒公司
  • 营销推广主要包括谷歌网站优化工具
  • 百度自建站网站被k多久恢复
  • 网站规划与网页设计案例百度小程序制作
  • 阿里云服务器可以做几个网站岳阳市官网
  • 网站开发者常见问题网站搭建设计 是什么
  • 网站设计公司推荐做超链接网站的代码
  • 智慧建设网站wordpress 加入字体库
  • 做一下网站需要什么重庆市建设工程质量协会网站