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

网站建设 容易吗营销做得好的品牌

网站建设 容易吗,营销做得好的品牌,品牌策划公司经营范围,武汉大学人民医院招聘D-Modulo Nine 很妙的类似区间dp, 我自己是想不到,本题解题思路来自学长的博客: 长沙橘子猫 题意 有一个长度为 nnn 的序列,你可以给每个位置填 0∼90\sim90∼9 的一个数,有 mmm 个限制,每个限制 [li,ri…

D-Modulo Nine

很妙的类似区间dp, 我自己是想不到,本题解题思路来自学长的博客: 长沙橘子猫

题意

有一个长度为 nnn 的序列,你可以给每个位置填 0∼90\sim909 的一个数,有 mmm 个限制,每个限制 [li,ri][l_{i}, r_{i}][li,ri] 要求区间内的数相乘必须为 999 的倍数,问一共有多少种合法的填数方案。

思路

破题点:博主在定义自己的方程时意识到,区间是不连续的两个端点组成的,我们枚举前 iii 个数则是一位位顺序来的,这样转移方程就不会很顺利。
于是我们可以尝试往将区间也能随着我们顺序遍历来解决的方向虑,于是就引申出解法中,以右端点编号将所有右端点相同的区间的左端点存入同一个桶的做法。 (实际上我们只需要存最大左端点即可)

而我们每遍历一位数,枚举当前可能填入的数之后就可以着手考虑如何让右端点为 iii 的所有区间合法考虑,因为我们找到只要区间内包含两个及以上的 333 就能保证合法(0/90/90/9 本身就代表两个 333),于是就能引申出dp方程的状态 j,kj,kjk 分别代表离 iii 最近的两个 333 的位置,dpjkdp_{jk}dpjk,就能轻易根据当前 iii 桶里存储的区间来判断 dpjkdp_{jk}dpjk 的方案合不合法。

代码

#include <bits/stdc++.h>
using namespace std;
#define ll long long
const int N = 60, mod = 1e9 + 7;
int n, m;
ll f[N][N]; //前i个数 当前已经填过的数的最后一个3在j, 倒数第二个在i
vector<int>g[N];void add(ll &x, ll y){x = (x + y + mod) % mod;
}void solve(){for(int i = 0; i <= n; i ++){g[i].clear();for(int j = 0; j <= n; j ++) f[i][j] = 0;}for(int i = 1; i <= m; i ++){int l, r;cin >> l >> r;g[r].push_back(l); // 根据右端点存储左端点, 其实根据转移方程只需要记录最大的左端点即可,因为只要最大的左端点被满足,那么小一些的肯定也能被满足}f[0][0] = 1;for(int i = 1; i <= n; i ++){/* 计算所有可能结果 */for(int j = i - 1; ~j; j --){for(int k = j; ~k; k --){if(f[k][j] != -1){add(f[i][i], f[k][j] * 2); // 0 / 9add(f[j][i], f[k][j] * 2); // 3 / 6f[k][j] = f[k][j] * 6 % mod; // 非3的倍数}}}/* 根据所给区间剔除不合法的解 */for(auto l : g[i]){ // 根据当前填数的点为右端点遍历所有的左端点, 那么对于所有区间l ~ i 中没有两个以上3的都视为不合法for(int j = 0; j < l; j ++){for(int k = j; k <= i; k ++){f[j][k] = -1;}}}}ll ans = 0;for(int i = 0; i <= n; i ++){for(int j = 0; j <= i; j ++) {if(f[j][i] != -1) add(ans, f[j][i]);}}cout << ans << "\n";
}int main(){ios::sync_with_stdio(false);cin.tie(nullptr); cout.tie(nullptr);while(cin >> n >> m){solve();}return 0;
}
http://www.hengruixuexiao.com/news/22034.html

相关文章:

  • 无锡专业网络推广公司seo怎样优化网站
  • 企业电商网站商城建设网络营销策划书怎么写
  • 上海网站建设褐公洲司app推广多少钱一单
  • 枣庄网站建设枣庄推广产品
  • 网站建设公司怎么找渠道网站运营课程
  • 银川做网站橙子建站怎么收费
  • 武汉营销型网站建设全国免费发布广告信息平台
  • 建站之星成品网站源码如何建立网址
  • 邢台做网站推广花关键词排名系统
  • 微孝感网站建设广州百度竞价外包
  • 又一个wordpress站点怎么进网站建设哪个公司好
  • 残疾人网站服务平台网站用户体验优化
  • 网站域名证书查询搜索引擎推广方法
  • 网站建站建设联系电话如何建立自己的网站
  • 金华网站建设平台关键词查询神器
  • 网站推广中应注意哪些事项今日国内新闻重大事件
  • 网站备案要多长时间湖南网站建设推广优化
  • 网站建设构想广州推动优化防控措施落地
  • 轻量应用服务器做网站免费查权重工具
  • 做网站生意多吗如何免费建立一个网站
  • 个人网站备案通过做淘客长沙seo推广公司
  • 做网站是需要多少钱网络推广网站推广方法
  • 手机网站 案例天津的网络优化公司排名
  • 哪里做企业网站广告公司起名大全最新
  • 新网站建设流程seo课程
  • 义乌外贸网站建设网店推广有哪些
  • 做网站送的企业邮箱能用吗seo搜索是什么
  • 上海网站建设求职简历营销公司网站
  • 网站开发怎么做他达拉非片正确服用方法
  • 百度优化网站建设日结app推广联盟