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

网站维护进不去怎么办团购网站营销方案

网站维护进不去怎么办,团购网站营销方案,采购管理系统的功能有哪些,公司网站建设必要性题目背景 蛟川书院的一道练习题QAQ 题目描述 如果一个数的所有连续三位数字都是大于100的素数,则该数称为三素数数。比如113797是一个6位的三素数数。 输入格式 一个整数n(3 ≤ n ≤ 10000),表示三素数数的位数。 输出格式 …

题目背景

蛟川书院的一道练习题QAQ

题目描述

如果一个数的所有连续三位数字都是大于100的素数,则该数称为三素数数。比如113797是一个6位的三素数数。

输入格式

一个整数n(3 ≤ n ≤ 10000),表示三素数数的位数。

输出格式

一个整数,表示n位三素数的个数m,要求输出m除以10^9 + 9的余数。

输入输出样例

输入 #1复制

4

输出 #1复制

204

说明/提示

区域动归QAQ

解析:

第一次的错误做法:

f[i] 表示前 i 为的三素数的个数,f[i]=f[i-3]*t+f[i-2]+f[i-1], t 表示 1 到 1e3 内的素数的个数

这个做法是错误的,题目的意思应该是任意三个连续的数组成的三位数一定是素数,上述的做法只考虑了当前连续的三个数,而非任意任意三个连续的数,所以上述做法是错误的

正确的做法:

最容易,最直接的划分方式:f[i][j][k][l] 表示前 i 位,最近的三位数,百位为 j ,十位为 k,个位为 l 的三素数个的个数

状态转移方程:f[i][j][k][l]=(f[i-1][k][l][p]+f[i][j][k][l])%mod;

初始化 f[3][j][k][l]=1;

时间复杂度为O(1e3*n),最坏情况为 1e8

优化:

我们可以发现上述划分集合的最后一维是可以省去的:

f[i][j][k] 表示: 最近的三位数,百位为 j ,十位为 k,个位为 l 的三素数个的个数,这里 l 省去了,

f[i][j][k]=(f[i][j][k]+f[i-1][k][l])%mod;

初始化可以不改变,也可以改为:f[2][j][k]=1;

优化前的代码:
 

#include<iostream>
#include<string>
#include<cstring>
#include<cmath>
#include<ctime>
#include<algorithm>
#include<utility>
#include<stack>
#include<queue>
#include<vector>
#include<set>
#include<math.h>
#include<map>using namespace std;
typedef long long LL;
const int N = 1e4 + 3, M = 1e3,mod=1e9+9;
int n;
LL f[N][11][11][11];
int an[M];
vector<int>prime;void init() {an[1] = 1;for (int i = 2; i < M; i++) {if (an[i] == 0) {prime.push_back(i);}for (int j = 0; j < prime.size() && prime[j] * i < M; j++) {an[prime[j] * i] = 1;}}
}int main() {init();cin >> n;for (int j = 1; j <= 9; j++) {for (int k = 0; k <= 9; k++) {for (int l = 0; l <= 9; l++) {f[3][j][k][l] = 1;}}}int t=0,tt=0;for (int i = 4; i <= n; i++) {for (int j = 1; j <= 9; j++) {for (int k = 0; k <= 9; k++) {for (int l = 0; l <= 9; l++) {for (int p = 0; p <= 9; p++) {t = j * 100 + k * 10 + l;tt = k * 100 + l * 10 + p;if (!an[t]&&!an[tt]) {f[i][j][k][l] = (f[i - 1][k][l][p] + f[i][j][k][l])%mod;}}}}}}LL ans = 0;for (int j = 0; j <= 9; j++) {for (int k = 0; k <= 9; k++) {for (int l = 1; l <= 9; l++) {t = j * 100 + k * 10 + l;if (!an[t])ans = (ans + f[n][j][k][l]) % mod;}}}cout << ans << endl;return 0;
}

优化后的代码

#include<iostream>
#include<string>
#include<cstring>
#include<cmath>
#include<ctime>
#include<algorithm>
#include<utility>
#include<stack>
#include<queue>
#include<vector>
#include<set>
#include<math.h>
#include<map>using namespace std;
typedef long long LL;
const int N = 1e4 + 3, M = 1e3, mod = 1e9 + 9;
int n;
LL f[N][11][11];
int an[M];
vector<int>prime;void init() {an[1] = 1;for (int i = 2; i < M; i++) {if (an[i] == 0) {prime.push_back(i);}for (int j = 0; j < prime.size() && prime[j] * i < M; j++) {an[prime[j] * i] = 1;}}
}int main() {init();cin >> n;for (int j = 0; j <= 9; j++) {for (int k = 0; k <= 9; k++) {f[2][j][k] = 1;}}int t = 0, tt = 0;for (int i = 3; i <= n; i++) {for (int j = 1; j <= 9; j++) {for (int k = 0; k <= 9; k++) {for (int l = 0; l <= 9; l++) {t = j * 100 + k * 10 + l;if (!an[t]) {f[i][j][k] = (f[i - 1][k][l] + f[i][j][k]) % mod;}}}}}LL ans = 0;for (int j = 0; j <= 9; j++) {for (int k = 0; k <= 9; k++) {ans = (ans + f[n][j][k]) % mod;}}cout << ans << endl;return 0;
}

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

相关文章:

  • 学网页制作的网站专业恶意点击软件
  • 重庆网站建设齐重庆零臻科技国产免费crm系统有哪些
  • 网站开发搜索功能wordpress 主题模板下载失败
  • 青岛专业网站建设推广报价数字营销策略有哪些
  • 酷站是什么网站网站建设丶金手指下拉11
  • 网站开发的价格seo关键词排名优化价格
  • 网站建设类的职位易站网站建设
  • wordpress关键词位置宁波seo优势
  • 企业大学网站建设计划个人主页网站设计论文
  • 服务器租用1元河南seo推广公司
  • 做网站刷东西珠海模板建站平台
  • 自己公司内网网站和外网怎么做同步品牌搜索引擎服务优化
  • 怎样做直播网站一键急速安装wordpress
  • 傻瓜使用模板建网站做门窗做什么网站好
  • 池州网站建设兼职wordpress伪造ip
  • 网站管理人员队伍建设说明材料室内设计行业现状及发展前景
  • 硬件开发工资高吗南阳做网站seo的
  • 凡科网站建设网站做外贸是网站好还是展会好
  • 哈尔滨住房和城乡建设局网站首页wordpress中文主题下载
  • 关于域名用于非网站用途的承诺书重庆市任免干部
  • 威海建设网站淄博建站哪家好
  • 最新购物网站建设框架wordpress文章自动内链
  • 小企业如何建网站91卫星地图手机版下载官网
  • wordpress京东客系统wordpress 数据库优化
  • 可以免费做网站推广的平台火星培训机构收费明细
  • wordpress网站更改主题信息网站做跳转微信打开
  • 网站后台管理系统 asp做物业管理的企业网站
  • 怎么提高网站转化率合肥网站的优化
  • 网站到底备案好不好潍坊信息网网站建设
  • 营销网站的策划方案怎么做html代码编写