P5440 【XR-2】奇迹 (大模拟dfs+欧拉筛板子+闰年)

传送门https://www.luogu.com.cn/problem/P5440

相信奇迹的人,本身就和奇迹一样了不起。------笛亚 《星游记》

思路历程:很离谱的一题,在理论上并不困难,只要简单dfs+欧拉筛就能过。在一开始,我采用了倒着模拟的思路,用stoi函数,强转字符串,发现样例能跑,但是仍旧RE(现在仍未理解这样的原因),于是,我选择了另一种做法,反过来遍历。

下面是代码:

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<cmath>
#include<set>
#include<string>
using namespace std;
const int N=1e8+5;
int _;
string s;
int ans;
bool nums[N];//这两行
long long f[10000001],cot=0;//这两行是欧拉筛的板子
int months[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};//减少代码量,开一个月份数组
bool check(int num){//检查年份符不符合逻辑
	int day=num%100;
	int month=(num/100)%100;
	int year=num/10000;
	if((year%4==0&&year%100!=0)||year%400==0){
		months[2]=29;
	}
	else months[2]=28; 
	return year>=1&&year<=9999&&month>=1&&month<=12&&day>=1&&day<=months[month];
}

void dfs(int x,int num){//第x层,数字为num
    int sum;//记录每一层要加多少
    if(x==8&&check(num)&&!nums[num]&&!nums[num%10000]&&!nums[num%100]){//100和10000
    	ans++;//2 4 8都要是素数
    }
    else if(x==8) return;//只要是8就返回
	else if(s[x]!='-'){
		sum=(s[x]-'0')*pow(10,7-x);//字符串转数字  要注意减去'0'
		dfs(x+1,num+sum);
	}
	else{
		if(x==4){//特判优化,减少for的遍历(月份)
			for(int i=0;i<2;++i){
				sum=i*pow(10,7-x);
				dfs(x+1,sum+num);
			}
		}
		else if(x==6){//特判优化(日子)
			for(int i=0;i<4;++i){
				sum=i*pow(10,7-x);
				dfs(x+1,sum+num);
			}
		}
		else{
			for(int i=0;i<=9;++i){
				sum=i*pow(10,7-x);
				dfs(x+1,sum+num);
			}
		}
	}
	
}

void solve(){
	ans=0;
	cin>>s;
	dfs(0,0);(从第0层开始)
	cout<<ans<<endl;
}

int main(){
	nums[1]=true;//1不是素数  true就不是素数 
	long long n=1e8;
    for(long long i=2;i<=n;i++)
    {
        if(!nums[i])
            f[cot++]=i;
        for(long long j=0;j<cot&&i*f[j]<=n;j++)
        {
            nums[f[j]*i]=true;
            if(i%f[j]==0)
                break;
        }
    }//从开头到这里就是一个欧拉筛的板子
	cin>>_;
	while(_--){
	    solve();	
	}
	return 0;
}
相关推荐
weixin_458872611 天前
东华复试OJ二刷复盘2
算法
Charlie_lll1 天前
力扣解题-637. 二叉树的层平均值
算法·leetcode
爱淋雨的男人1 天前
自动驾驶感知相关算法
人工智能·算法·自动驾驶
乌萨奇也要立志学C++1 天前
【洛谷】图论入门:从基本概念到代码实现(邻接矩阵、邻接表、DFS/BFS)
深度优先·图论·宽度优先
wen__xvn1 天前
模拟题刷题3
java·数据结构·算法
滴滴答滴答答1 天前
机考刷题之 6 LeetCode 169 多数元素
算法·leetcode·职场和发展
Neteen1 天前
【数据结构-思维导图】第二章:线性表
数据结构·c++·算法
礼拜天没时间.1 天前
力扣热题100实战 | 第25期:K个一组翻转链表——从两两交换到K路翻转的进阶之路
java·算法·leetcode·链表·递归·链表反转·k个一组翻转链表
Swift社区1 天前
LeetCode 400 第 N 位数字
算法·leetcode·职场和发展
再难也得平1 天前
力扣239. 滑动窗口最大值(Java解法)
算法·leetcode·职场和发展