【题解】魔术棋子

题目描述

在一个M×N的魔术棋盘中,每个格子中均有一个整数,当棋子走进这个格子中,则此棋子上的数会被乘以此格子中的数。一个棋子从左上角走到右下角,只能向右或向下行动,请问此棋子走到右下角后,模(mod)K可以为几?
如以下2×3棋盘:
3 4 4
5 6 6
棋子初始数为1,开始从左上角进入棋盘,走到右下角,上图中,最后棋子上的数可能为288,432或540。所以当K=5时,可求得最后的结果为:0,2,3。

输入输出格式

输入格式:

第一行为三个数,分别为M,N,K(1≤M,N,K≤100);
以下M行,每行N个数,分别为此方阵中的数。

输出格式:

第一行为可能的结果个数;
第二行为所有可能的结果(按升序输出)。

输入输出样例

输入样例:

2 3 5
3 4 4
5 6 6

输出样例:

3
0 2 3

这道题随便搜索一下,每搜索一次就取模一次嘛

#include<iostream>
using namespace std;
int line,list,k,s[105][105];
int p,ans[25],check[105];
void dfs(int x,int y,int magic)
{
    if(x<1||y<1||x>line||y>list) return;
    magic*=s[x][y];
    magic%=k;
    if(x==line&&y==list)
    {
        if(check[magic]==1) return;
        check[magic]=1;
        ans[++p]=magic;
        return;
    }
    dfs(x+1,y,magic);
    dfs(x,y+1,magic);
}
int main()
{
    cin>>line>>list>>k;
    for(register int i=1;i<=line;++i)
    {
        for(register int j=1;j<=list;++j)
        {
            cin>>s[i][j];
        }
    }
    dfs(1,1,1);
    cout<<p<<endl;
    for(register int i=1;i<p;++i) cout<<ans[i]<<" ";
    cout<<ans[p];
}

……然后就只有20分,8个点全部TLE
想一想就计划吧
如果来到这个点时得到的结果以前出现过,那么这条路就被我找过了,就直接返回了。
AC代码:

#include<iostream>
#include<algorithm>
using namespace std;
int line,list,k,s[105][105];
int p,ans[105],check[105];
int rmb[105][105][105];
void dfs(int x,int y,int magic)
{
    if(x<1||y<1||x>line||y>list) return;
    magic*=s[x][y];
    magic%=k;
    if(rmb[x][y][magic]==1) return;
    if(x==line&&y==list)
    {
        if(check[magic]==1) return;
        check[magic]=1;
        ans[++p]=magic;
        return;
    }
    dfs(x+1,y,magic);
    dfs(x,y+1,magic);
    rmb[x][y][magic]=1;
}
int main()
{
    cin>>line>>list>>k;
    for(register int i=1;i<=line;++i)
    {
        for(register int j=1;j<=list;++j)
        {
            cin>>s[i][j];
        }
    }
    dfs(1,1,1);
    sort(ans+1,ans+1+p);
    cout<<p<<endl;
    for(register int i=1;i<p;++i) cout<<ans[i]<<" ";
    cout<<ans[p];
}

转载于:https://www.cnblogs.com/2021-yanghaoran/p/11172064.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值