点灯游戏求解算法(DFS)——老子表示不理解!也不看了!

2 篇文章 0 订阅
#include<cstdio>
#include<cstring>
const int Row=4,Col=4;
int status[Row][Col]={
    1,0,0,0,
    0,1,1,1,
    0,1,1,1,
    0,1,1,1
};
int minstep=200;
int nowstep=0;
int steps[200];
int beststeps[200];
void click(int pos)
{
    int r=pos/4,c=pos%4;
    status[r][c]=!status[r][c];
    for(int i=0;i!=Row;i++)
        status[i][c]=!status[i][c];
    for(int i=0;i!=Col;i++)
        status[r][i]=!status[r][i];
    steps[pos]=!steps[pos];
}
bool win()
{
    for(int i=0;i<Row;i++)
    {     for(int j=0;j<Col;j++)
        if(!status[i][j])
            return false;
    }
    return true;
}

void DFS(int step)
{
    if(step==Row*Col) return;
    if(nowstep>=minstep) return;
    if(win()) {
        minstep=nowstep;memcpy(beststeps,steps,sizeof(beststeps));return;}
    
    DFS(step+1);
    nowstep++;
    click(step);
    DFS(step+1);
    nowstep--;
    click(step);
    
}
int main()
{
    DFS(0);
    printf("%d\n",minstep);
    for(int i=0;i<Row*Col;i++)
        if(beststeps[i])
            printf("(%d,%d) ",i/4+1,i%4+1);
}

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SmartFusion是一款集成了FPGA和ARM处理器的可编程逻辑器件。在使用SmartFusion进行FPGA到ARM的衔接过程中,首先我们可以通过MSS(Microcontroller Subsystem)模块的GPIO(General Purpose Input/Output)功能来实现点灯。 MSS是SmartFusion芯片中的一个微控制器子系统,它包含了ARM Cortex-M3处理器以及与之相关的外设。GPIO是MSS提供的一种功能,它允许我们通过配置相关引脚的输入输出状态来进行数字信号的输入输出。 在使用MSS_GPIO点灯的过程中,首先我们需要使用SmartFusion的设计工具进行硬件电路的设计。接着,我们需要在软件开发环境中编写ARM处理器的代码来控制MSS_GPIO。 在代码中,我们需要进行以下步骤来实现点灯功能: 1. 配置MSS_GPIO控制的引脚作为输出引脚。我们可以通过设置相应的寄存器来实现这一步骤。例如,我们可以将寄存器的特定位设置为1来将某个引脚设置为输出模式。 2. 设置输出引脚的电平状态。通过编写相应的代码,我们可以将输出引脚的电平配置为高电平或低电平。这将决定LED是否点亮。 3. 可以加入延时函数来控制点亮和熄灭的时间间隔,以及闪烁的频率。 以上就是使用SmartFusion的MSS_GPIO模块实现点灯的简要过程。通过编写ARM处理器的代码,配置相关的寄存器,我们可以通过控制MSS_GPIO模块的引脚状态来实现LED的点亮和熄灭。这个简单的示例展示了SmartFusion芯片中FPGA和ARM之间的协同工作能力,为我们实现更复杂的功能提供了基础。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值