2022寒假牛客训练营五

D:数位小孩

题意 | 简单

给定一个区间 [l , r l,rl,r] ,求这个区间内有多少个数字满足以下条件:

每相邻两个数位和为素数

其中至少一个数位为1

没有前导零

0 ≤ \leq≤ l , r l,rl,r ≤ \leq≤ 1 0 10 10^{10}10

10

思路 | 暴力

因为数据范围不大,可以直接写一个dfs进行暴力寻找,把哪些数字可以相邻在一起的先预处理出来,然后就暴力开找就行啦

代码

#include <bits/stdc++.h>

#define int long long

#define pb push_back

using namespace std;

const int maxn = 1e6 + 100;

typedef long long ll;

ll prime[1006];

bool sf[2006];

void sushu() {

ll num = 0;

memset(sf, true, sizeof(sf));

sf[1] = false;

sf[0] = false;

for (int i = 2; i < 1000; i++) {

if (sf[i]) prime[++num] = i;

for (int j = 1; j <= num; j++) {

if (i * prime[j] > 1000) break;

sf[i * prime[j]] = false;

if (i % prime[j] == 0) break;

}

}

}

int l, r;

int ans1 = 0; int ans2 = 0;

vectorg[100];

void dfs(int x,int sum,int f) {

if (sum < l) {

if (f == 1) ans1++;

}

else return;

for (int i = 0; i < g[x].size(); i++) {

int to = g[x][i];

if (to == 1) dfs(to, sum * 10 + to, 1);

else dfs(to, sum * 10 + to, f);

}

}

void dfs2(int x, int sum,int f) {

if (sum <= r) {

if (f == 1) ans2++;

}

else return;

for (int i = 0; i < g[x].size(); i++) {

int to = g[x][i];

if (to == 1) dfs2(to, sum * 10 + to, 1);

else dfs2(to, sum * 10 + to, f);

}

}

void solve() {

for (int i = 0; i <= 9; i++) {

for (int j = 0; j <= 9; j++) {

if (sf[i + j])g[i].push_back(j);

}

}

cin >> l >> r;

for (int i = 1; i <= 9; i++) {

if (i == 1) {

dfs(i, i, 1);

dfs2(i, i, 1);

}

else {

dfs(i, i, 0);

dfs2(i, i, 0);

}

}

cout << ans2 - ans1 << endl;

}

signed main() {

int t; t = 1;

sushu();

while (t--) {

solve();

}

return 0;

}

相关推荐
Frostnova丶2 小时前
LeetCode 190.颠倒二进制位
java·算法·leetcode
骇城迷影3 小时前
代码随想录:链表篇
数据结构·算法·链表
专注前端30年3 小时前
智能物流路径规划系统:核心算法实战详解
算法
json{shen:"jing"}4 小时前
字符串中的第一个唯一字符
算法·leetcode·职场和发展
追随者永远是胜利者4 小时前
(LeetCode-Hot100)15. 三数之和
java·算法·leetcode·职场和发展·go
BlockWay5 小时前
西甲赛程搬进平台:WEEX以竞猜开启区域合作落地
大数据·人工智能·算法·安全
im_AMBER6 小时前
Leetcode 121 翻转二叉树 | 二叉树中的最大路径和
数据结构·学习·算法·leetcode
mit6.8247 小时前
二分+贪心
算法
programhelp_8 小时前
特斯拉 MLE 超详细面经 + 避坑
数据结构·人工智能·算法·面试·职场和发展
越甲八千8 小时前
深入了解迭代器erase()之后的失效逻辑
算法