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;

}

相关推荐
ゞ 正在缓冲99%…23 分钟前
leetcode75.颜色分类
java·数据结构·算法·排序
奋进的小暄1 小时前
贪心算法(15)(java)用最小的箭引爆气球
算法·贪心算法
Scc_hy1 小时前
强化学习_Paper_1988_Learning to predict by the methods of temporal differences
人工智能·深度学习·算法
巷北夜未央1 小时前
Python每日一题(14)
开发语言·python·算法
javaisC1 小时前
c语言数据结构--------拓扑排序和逆拓扑排序(Kahn算法和DFS算法实现)
c语言·算法·深度优先
爱爬山的老虎1 小时前
【面试经典150题】LeetCode121·买卖股票最佳时机
数据结构·算法·leetcode·面试·职场和发展
SWHL1 小时前
rapidocr 2.x系列正式发布
算法
雾月552 小时前
LeetCode 914 卡牌分组
java·开发语言·算法·leetcode·职场和发展
想跑步的小弱鸡2 小时前
Leetcode hot 100(day 4)
算法·leetcode·职场和发展
Fantasydg2 小时前
DAY 35 leetcode 202--哈希表.快乐数
算法·leetcode·散列表