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

个人做的小网站需要备案外贸论坛福步

个人做的小网站需要备案,外贸论坛福步,无锡自助建网站,WordPress去掉由开发P2704 题目题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1提示 解题思路分析Code更多方法 题目 原题链接 题目描述 司令部的将军们打算在 N M N\times M NM 的网格地图上部署他们的炮兵部队。 一个 N M N\times M NM 的地图由 N N N 行 M M M 列组成#x… P2704 题目题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1提示 解题思路分析Code更多方法 题目 原题链接 题目描述 司令部的将军们打算在 N × M N\times M N×M 的网格地图上部署他们的炮兵部队。 一个 N × M N\times M N×M 的地图由 N N N 行 M M M 列组成地图的每一格可能是山地用 H \texttt{H} H 表示也可能是平原用 P \texttt{P} P 表示如下图。 在每一格平原地形上最多可以布置一支炮兵部队山地上不能够部署炮兵部队一支炮兵部队在地图上的攻击范围如图中黑色区域所示 如果在地图中的灰色所标识的平原上部署一支炮兵部队则图中的黑色的网格表示它能够攻击到的区域沿横向左右各两格沿纵向上下各两格。 图上其它白色网格均攻击不到。从图上可见炮兵的攻击范围不受地形的影响。 现在将军们规划如何部署炮兵部队在防止误伤的前提下保证任何两支炮兵部队之间不能互相攻击即任何一支炮兵部队都不在其他支炮兵部队的攻击范围内在整个地图区域内最多能够摆放多少我军的炮兵部队。 输入格式 第一行包含两个由空格分割开的正整数分别表示 N N N 和 M M M。 接下来的 N N N 行每一行含有连续的 M M M 个字符按顺序表示地图中每一行的数据。 输出格式 一行一个整数表示最多能摆放的炮兵部队的数量。 样例 #1 样例输入 #1 5 4 PHPP PPHH PPPP PHPP PHHP样例输出 #1 6提示 对于 100 % 100\% 100% 的数据 1 ≤ N ≤ 100 1 \leq N\le 100 1≤N≤100 1 ≤ M ≤ 10 1 \leq M\le 10 1≤M≤10保证字符仅包含 P 与 H。 解题思路 分析 由于每一行都受上两行的状态的影响所以我们需要开三维数组。 我们令 1 1 1 表示此地放了阵地 0 0 0 则表示没有。 定义 f [ i ] [ s ] [ s 1 ] f[i][s][s1] f[i][s][s1] 表示当前在第 i i i 行本行状态为 s s s上一行状态为 s 1 s1 s1 时最多有几个阵地。 则循环枚举有 f[i][s][s1]max(f[i][s][s1],f[i-1][s1][s2]a[s]);其中 s 2 s2 s2 为上两行状态 a [ s ] a[s] a[s] 表示当状态为 s s s 时放了几个阵地。 但必须满足 状态 s , s 1 , s 2 s,s1,s2 s,s1,s2 均是合法状态。 s 2 s2 s2 不影响 s , s 1 s,s1 s,s1 s 1 s1 s1 不影响 s s s。 所以纯暴力的代码就已经出来了不过 时间复杂度 O ( n m 2 8 m ) O(nm^28^m) O(nm28m) 空间复杂度 O ( n 4 m ) O(n 4^m) O(n4m) 好吧根本不会炸。 考虑优化 对于每个 a [ i ] a[i] a[i]可以预处理解决。对于每个状态 s s s 本身是否合法可以预处理。对于每个状态 s s s 的下一行有几个合法状态可以预处理。对于每个地形可以用二进制来表示 1 1 1 为山地 0 0 0 为平地。判断是 一下就行了。第一维的 i i i 可以滚动掉。 对于 1 很简单 inline int ga(int x) {int cnt0;while(x0){if(x1)cnt;x1;}return cnt; }对于 2 inline bool check(int x) {return !(((x2)x)|(x(x1))); }for(int i0;i(1m);i)if(check(i))s.push_back(i);即每两个 1 1 1 之间至少隔两个 0 0 0。 对于 3 int lens.size();for(int i0;ilen;i)for(int j0;jlen;j)if(!(s[i]s[j]))Q[s[i]].push_back(s[j]);对于 4 同样很简单 for(int i1;in;i){for(int j1;jm;j){cinc;g[i](g[i]1)(cH);}}Code #includebits/stdc.h #define int long long #define IOS ios::sync_with_stdio(false),cin.tie(NULL),cout.tie(NULL); using namespace std; const int N110; vectorints; vectorintQ[N]; int n,m,f[101][N][N],g[200],a[N]; char c; inline bool check(int x) {return !(((x2)x)|(x(x1))); } inline int ga(int x) {int cnt0;while(x0){if(x1)cnt;x1;}return cnt; } signed main() {IOS;cinnm;for(int i1;in;i){for(int j1;jm;j){cinc;g[i](g[i]1)(cH);}}for(int i0;i(1m);i)if(check(i))s.push_back(i),a[i]ga(i);int lens.size();for(int i0;ilen;i)for(int j0;jlen;j)if(!(s[i]s[j]))Q[s[i]].push_back(s[j]);int Y0;for(int i1;in;i){for(int j0;jlen;j){ Y;int Ss[j];if(!(g[i]S)){int LQ[S].size();for(int k0;kL;k){int S1Q[S][k];int LeQ[S1].size();for(int u0;uLe;u){int S2Q[S1][u];if((SS2)||(S1g[i-1])||(S2g[i-2]))continue;f[i][S][S1]max(f[i][S][S1],f[i-1][S1][S2]a[S]);}}}}}int ans0;for(int i0;ilen;i)for(int j0;jQ[s[i]].size();j)ansmax(ans,f[n][s[i]][Q[s[i]][j]]);coutans;return 0; }空间复杂度 O ( 4 m ) O(4^m) O(4m) 时间复杂度 O ( n 8 m ) O(n8^m) O(n8m) 而由于优化过后了时间复杂度远远跑不满实际复杂度约为 O ( 60 × [ 20 , 40 ] 2 × n ) O(60\times [20,40]^2 \times n) O(60×[20,40]2×n) 更多方法 更多方法
http://www.huolong8.cn/news/295424/

相关文章:

  • 为什么做彩票网站会被提示危险南通网站开发公司
  • 哪个网站做免费广告好网站包装推广案例
  • 怎么搞到网站免费微信网站开发
  • 网站对于企业的好处用asp做网站出现空白
  • 旅游网站哪个做的好素材网站设计模板
  • 多种网站建设网站设计与运营
  • 微网站 pc端网站开发怎么自己做网站教程
  • 个人微信公共号可以做微网站么wordpress反应
  • 网站怎么做可以合法让别人充钱中国建筑网信息网
  • 网站正在建设页面模板js做网站登录框验证码
  • 网站所有页面只显示域名网站源码是什么
  • 网站推广的渠道计算机应用技术网站开发方向
  • 网站开发师贴吧node.js可以做网站么
  • 青岛网站建设服务中心设计网站需提供什么
  • 网站建设 业务澧县网站设计
  • 上海网站建设大概多少钱费用网站建设
  • 威海建设集团招聘信息网站网站建设费1万多入什么科目
  • 如何通过网站做网上报名系统自己做网站赚钱吗
  • 网站群建设存在的问题泰安房产最新网签情况
  • 深圳做网站应该怎么做陕西省档案馆建设网站
  • 网站建设公司是干嘛的MUSIK V1.0 WORDPRESS
  • 建设银行 商户网站打不开网站优化设计公司
  • 网站怎么做速排如何让新网站
  • 企业网站源码 thinkphp国外可以用什么网站做问卷
  • p2p网贷网站建设方案网站服务器多少钱一月
  • 图片分享网站源码设计方案评价
  • 电商设计网站哪个好网页源代码修改了影响别人吗
  • 工信部怎么查网站备案高端外贸网站建设
  • 网站开发前景知乎杭州知名的网站制作策略
  • 做类似淘宝一样的网站有哪些兴义市建设局网站首页