当前位置: 首页 > news >正文

做网站维护新乡网站seo

做网站维护,新乡网站seo,辽宁建设工程信息网注册,建设银行客户端官方网站题目描述 一个如下的 6 x 6 的跳棋棋盘,有六个棋子被放置在棋盘上,使得每行、每列有且只有一个,每条对角线(包括两条主对角线的所有平行线)上至多有一个棋子。 上面的布局可以用序列 2 4 6 1 3 5 来描述,第…

题目描述

一个如下的 6 x 6 的跳棋棋盘,有六个棋子被放置在棋盘上,使得每行、每列有且只有一个,每条对角线(包括两条主对角线的所有平行线)上至多有一个棋子。

 

上面的布局可以用序列 2 4 6 1 3 5 来描述,第 i 个数字表示在第 i 行的相应位置有一个棋子,如下:

行号 1 2 3 4 5 6

列号 2 4 6 1 3 5

这只是棋子放置的一个解。请编一个程序找出所有棋子放置的解。  
并把它们以上面的序列方法输出,解按字典顺序排列。  
请输出前 3 个解。最后一行是解的总个数。

输入格式

一行一个正整数 n,表示棋盘是 n x n 大小的。

输出格式

前三行为前三个解,每个解的两个数字之间用一个空格隔开。第四行只有一个数字,表示解的总数。

样例 #1

样例输入 #1
6

样例输出 #1
2 4 6 1 3 5
3 6 2 5 1 4
4 1 5 2 6 3
4

提示

【数据范围】  
对于 100% 的数据,6 <= n <= 13。

题目翻译来自NOCOW。

USACO Training Section 1.5

这是深搜的经典题目,可以分别对行,列,对角线做标记来做这道题。其中我们可以发现,一条对角线上,行和列的和和差的值是一样的。

#include <iostream>
using namespace std;
const int N = 100;
int a[N], b[N], c[N], d[N];//分别表示行,列和当前坐标的两条对角线
int n, total;
void queen(int x)
{if (x > n){if (total <= 2)//只输出前三个答案{for (int j = 1; j <= n; j++)cout << a[j] << " ";cout << "\n";}total++;return;}else{for (int i = 1; i <= n; i++){if (!b[i] && (!c[i + x]) && (!d[x - i + n])){a[x] = i;b[i] = 1;c[i + x] = 1;d[x - i + n] = 1;queen(x + 1);//遍历下一个b[i] = 0;//恢复标记c[i + x] = 0;d[x - i + n] = 0;}}}
}
int main()
{cin >> n;queen(1);//第一个皇后cout << total;
}

http://www.khdw.cn/news/5624.html

相关文章:

  • visio网站建设流程图今日热搜前十名
  • 上海科技网站建设天桥区seo全网宣传
  • 邪恶做动态网站腾讯企点客服
  • 深度网营销型网站建设公司怎么样百度百家官网入口
  • 全国做网站最好的公司有哪些希爱力的功效及副作用
  • 网站设计宽度尺寸手机优化
  • 如何做阿里巴巴的网站爱网站查询挖掘工具
  • 网站建设优化新疆南宁做网站公司
  • 郓城县住房和建设局网站搜索引擎优化技术
  • 网站优化建设绵阳房地产销售技巧和话术
  • 网站关键词优化多少钱百度seo词条优化
  • 搭建网站需要什么技术云浮新增确诊病例30例
  • 做网站 超速云刚出来的新产品怎么推
  • 张店网站制作价格低网建
  • 网站三大标签百度竞价推广托管
  • 做卫生用品的网站优化关键词排名推广
  • 营销网站开发哪家好app拉新怎么对接渠道
  • 房屋设计装修app知乎推广优化
  • 公司网站可以自己做么制作一个网站的全过程
  • 南通网站制作专家线上推广有哪些
  • 一个网站如何优化百度排名查询
  • 搭建个人网站的步骤公司网站建设方案
  • 做网站什么什么新的营销方式有哪些
  • 做网站公司哪里好百度投稿平台
  • 湖北什么是网站建设优化算法
  • dede网站首页被劫持企业营销咨询
  • 青岛模板化网站建设黄页88网
  • 甘肃省建设厅不动产网站整合营销传播的六种方法
  • 2022最新泛站群程序给公司做网站的公司
  • wordpress调用文章描述广州seo优化排名公司