时间限制:0.75s

空间限制:6M

题意

n*n(n<=10)的棋盘,求出放置m(m<=n*n)个皇后的方案数。


Solution:

状态压缩+位运算  搜索。

首先我们从上往下逐行放置,

DFS(line, row, l, r, k)

line :当前行号

row:列状态

l:\ 左上对角线状态

r:/右上对角线状态

k:已放置棋子数

对于每一行有不放或者放一个棋子两种方案

放一个棋子时又要考虑哪些位置可以放置,

状态压缩(row,r,l):

例如当n=4时

二进制数

1=(0001)2代表在第一个位置放置了棋子

同理(1111) 代表已经放满;

可放状态(pos):

15=(1111)代表全部位置可放

1=(0001) 代表右边第一个位置可放

0=(0000)代表无法再放

对(pos=~(l | row | r))   pos得到当前行所有可放置的位置(可以自己模拟一下)

数状数组中出现的 p= pos& - pos 得到最后一个1 的位置,即一个可放位置。

状态(row,l,r  )|  p 时,即更新当前行放置后的三个状态

例如  p=1(0001),当前放右一;

row=8(1000),左一已不可放。

row=p | row=9(1001),  即右一和左一都不可以再放

当line+1,即搜索下一行时,l和r变化

以左上对角线状态l为例

初始为(0000)

当右2放置1个棋子时,当前行(0010)

由于是左上对角线,下一行l变为(0001),即 l>>1;

r同理,即r<<1.

row列状态在行变化的时候不需要更新

代码

60ms+2KB  Accepted

#include <cstdio>
int n, sum, max, k, m;
void dfs (int line , int row, int l, int r, int k) {
int pos, p, i;
if (line > n){
if(k == m) sum++;
return;
}
dfs (line + 1, row, l>>1, r<<1, k);
if (row != max) {
pos = max & (~ (row | l | r) );
while (pos != 0) {
p = pos & -pos;
pos = pos - p;
dfs (line+1,row | p, (l | p) >> 1, (r | p) << 1, k + 1);
}
}
}
int main() {
scanf ("%d %d", &n, &m);
max = (1 << n) - 1;
dfs (1, 0, 0, 0, 0);
printf ("%d", sum);
}

  

  

SGU 224.Little Queens的更多相关文章

  1. 今日SGU 5.26

    #include<bits/stdc++.h> #define de(x) cout<<#x<<"="<<x<<endl ...

  2. Android Weekly Notes Issue #224

    Android Weekly Issue #224 September 25th, 2016 Android Weekly Issue #224 本期内容包括: Google Play的pre-lau ...

  3. SGU 495. Kids and Prizes

    水概率....SGU里难得的水题.... 495. Kids and Prizes Time limit per test: 0.5 second(s)Memory limit: 262144 kil ...

  4. ACM: SGU 101 Domino- 欧拉回路-并查集

    sgu 101 - Domino Time Limit:250MS     Memory Limit:4096KB     64bit IO Format:%I64d & %I64u Desc ...

  5. 【SGU】495. Kids and Prizes

    http://acm.sgu.ru/problem.php?contest=0&problem=495 题意:N个箱子M个人,初始N个箱子都有一个礼物,M个人依次等概率取一个箱子,如果有礼物则 ...

  6. SGU 455 Sequence analysis(Cycle detection,floyd判圈算法)

    题目链接:http://acm.sgu.ru/problem.php?contest=0&problem=455 Due to the slow 'mod' and 'div' operati ...

  7. SGU 422 Fast Typing(概率DP)

    题目大意 某人在打字机上打一个字符串,给出了他打每个字符出错的概率 q[i]. 打一个字符需要单位1的时间,删除一个字符也需要单位1的时间.在任意时刻,他可以花 t 的时间检查整个打出来的字符串,并且 ...

  8. Jeff Somers's N Queens Solutions 最快的n皇后算法

    /* Jeff Somers * * Copyright (c) 2002 * * jsomers@alumni.williams.edu * or * allagash98@yahoo.com * ...

  9. sgu 104 Little shop of flowers 解题报告及测试数据

    104. Little shop of flowers time limit per test: 0.25 sec. memory limit per test: 4096 KB 问题: 你想要将你的 ...

随机推荐

  1. Linux Shell编程(27)——子shell

    运行一个shell脚本时会启动另一个命令解释器. 就好像你的命令是在命令行提示下被解释的一样, 类似于批处理文件里的一系列命令.每个shell脚本有效地运行在父shell(parent shell)的 ...

  2. HDU-4570 Multi-bit Trie

    http://acm.hdu.edu.cn/showproblem.php?pid=4570 Multi-bit Trie Time Limit: 2000/1000 MS (Java/Others) ...

  3. [转]33 useful Keyboard Shortcuts for Run commond

    原文: http://www.shortcutworld.com/en/win/Run-command.html 1. Calling Run CommandWin + r               ...

  4. DSP知识

    自己认为是问题的问题,时常更新,为了记录学习的点点滴滴. 1.什么是boot loader ? DSP 的速度尽快,EPROM 或flash 的速度较慢, 而DSP 片内的RAM很快, 片外的RAM也 ...

  5. 乐视手机1S正式发售,乐视商城官网抽风遭网友吐槽

    乐视手机1S正式发售,乐视商城官网抽风遭网友吐槽 10月27日,乐视召开的新品发布会上正式推出千元金属新机乐1s,售价1099元.今天11月3日上午10:00,乐1s在乐视商城.京东商城首发开卖,现货 ...

  6. 【索引】UML学习笔记

    行为图 交互图 交互概览图 时间图 顺序图 通信图 活动图 状态及图 用例图 结构图 包图 类图 对象图 组件图 部署图 组合结构图

  7. [转]让程序在崩溃时体面的退出之CallStack

    原文地址:http://blog.csdn.net/starlee/article/details/6618849 在我的那篇<让程序在崩溃时体面的退出之Unhandled Exception& ...

  8. Delphi 对象的创建(create)与释放(free/destory)

    Delphi 对象的创建(create)与释放(free/destory) 1.Create参数为:nil/self/application的区别,最好能看到实际效果的区别 例如: My := TMy ...

  9. python 2 处理HTTP 请求的包

    httplib httplib: https://docs.python.org/2/library/httplib.html python 的官方文档这样说明: This module define ...

  10. 5 kafka整合storm

    本博文的主要内容有 .kafka整合storm   .storm-kafka工程  .storm + kafka的具体应用场景有哪些? 要想kafka整合storm,则必须要把这个storm-kafk ...