1.黑白游戏
考试的时候因为读题错误,qwq qwq。
2.扫雷游戏
状态压缩,存剩下炸弹状态为的情况。
3.路径异或游戏
折半搜索+trie树
两端搜索,然后在端点处维护trie树.
#include<bits/stdc++.h>
using namespace std;
const int N=21;
const int M=1e7+5;
int a[N][N],ans,n,X,rt[N][N],go[M][2],tot;
void Insert(int x,int u) {
for(int i=30;i>=0;i--) {
bool k=x&(1<<i);
if(!go[u][k]) go[u][k]=++tot;
u=go[u][k];
}
}
int Find(int x,int u) {
int res=0;
for(int i=30;i>=0;i--) {
bool k=x&(1<<i);
if(go[u][k^1]) u=go[u][k^1],res+=(1<<i);
else u=go[u][k];
}
return res;
}
void dfs1(int dep,int x,int y,int res) {
if(dep==n-1) {
if(!rt[x][y]) rt[x][y]=++tot;
Insert(res,rt[x][y]);
return;
}
dfs1(dep+1,x+1,y,res^a[x+1][y]);
dfs1(dep+1,x,y+1,res^a[x][y+1]);
}
void dfs2(int dep,int x,int y,int res) {
if(dep==n-1) {
ans=max(ans,Find(res^a[x][y],rt[x][y]));
return;
}
dfs2(dep+1,x-1,y,res^a[x-1][y]);
dfs2(dep+1,x,y-1,res^a[x][y-1]);
}
int main() {
scanf("%d%d",&n,&X);
for(int i=1;i<=n;i++) for(int j=1;j<=n;j++)scanf("%d",&a[i][j]);
dfs1(0,1,1,a[1][1]^X);
dfs2(0,n,n,a[n][n]);
printf("%d",ans);
return 0;
}
4.字符串游戏
KMP+dp
表示当前匹配到了A的i位,B的j位的总分
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=1e4+5;
const int M=105;
ll mod=998244353;
int n,m,fail[N];
ll dp[N][M];
char B[N];
void get_fail() {
for(int i=2,j=0;i<=m;i++) {
while(j&&B[i]!=B[j+1]) j=fail[j];
if(B[i]==B[j+1]) j++;
fail[i]=j;
}
}
ll solve() {
ll ans=0;
// for(int i=0;i<=n;i++) for(int j=0;j<=m;j++) dp[i][j]=1;
dp[0][0]=1;
for(int i=0;i<n;i++) {
for(int j=0;j<=m;j++) {
for(int k=0;k<5;k++) {
char ch=(char)(k+'a');
int p=j;
while(p&&ch!=B[p+1]) p=fail[p];
if(ch==B[p+1]) p++;
if(p==m)dp[i+1][p]=(dp[i+1][p]+dp[i][j]*2%mod)%mod;
else dp[i+1][p]=(dp[i+1][p]+dp[i][j])%mod;
}
}
}
for(int j=0;j<=m;j++) ans=(ans+dp[n][j])%mod;
// printf("%d\n",ans);
return ans;
}
ll ksm(ll a,ll b) {
ll res=1;
for(;b;b>>=1,a=a*a%mod) if(b&1)res=res*a%mod;
return res;
}
int main() {
scanf("%d%d",&n,&m);
scanf("%s",B+1);
get_fail();
// for(ll i=1;i<=1000;i++) if(i*ksm(ksm(5,n),mod-2)%mod==503115155) printf("%d\n",i);
printf("%lld",1ll*solve()*ksm(ksm(5,n),mod-2)%mod);
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人