SQL大赛——5X5方格棋盘难题

简介:
“盛拓传媒杯”SQL大赛第一期答题,
本期题目:5X5方格棋盘难题

在5X5的方格棋盘中(如图),每行、列、斜线(斜线不仅仅包括对角线)最多可以放两个球,如何摆放才能放置最多的球,这样的摆法总共有几种?输出所有的摆法。
要求: 用一句SQL实现。
输出格式: 从方格棋盘第一行至第5行,每行从第一列到第5列依次输出,0表示不放球,1表示放球。例如:1001000000000000000000000。一行输出一个行号和一个解,按解所在的列字符串顺序从大到小排序。

数据库平台: 适用Oracle、MS SQL Sever,版本(Oracle推荐10gr2(包含)以上版本、MS SQL Sever推荐2008版本)

我个人的答案如下:
--构造0、1选项
with test as
(select '1' bit from dual union select '0' from dual),
--构造每行排列组合
combostring as
(
select replace(sys_connect_by_path(bit,'#'),'#') combo
from test
where level=5
connect by level<=5
),
--把“10001”的字符串,构造成可计算的数字
combo as
(select substr(combo,1,1) b1,substr(combo,2,1) b2,substr(combo,3,1) b3,substr(combo,4,1) b4,substr(combo,5,1) b5
 from combostring),
--根据题目进行逻辑求解
allcombo as
(
select c1.b1||c1.b2||c1.b3||c1.b4||c1.b5||' '||c2.b1||c2.b2||c2.b3||c2.b4||c2.b5||' '||
       c3.b1||c3.b2||c3.b3||c3.b4||c3.b5||' '||c4.b1||c4.b2||c4.b3||c4.b4||c4.b5||' '||c5.b1||c5.b2||c5.b3||c5.b4||c5.b5 combo,
 RANK() OVER(ORDER BY  
 c1.b1+c1.b2+c1.b3+c1.b4+c1.b5+ c2.b1+c2.b2+c2.b3+c2.b4+c2.b5+ c3.b1+c3.b2+c3.b3+c3.b4+c3.b5+ c4.b1+c4.b2+c4.b3+c4.b4+c4.b5+ c5.b1+c5.b2+c5.b3+c5.b4+c5.b5 DESC) RANK
  from combo c1,combo c2,combo c3,combo c4,combo c5
 where c1.b1+c2.b1+c3.b1+c4.b1+c5.b1<=2
   and c1.b2+c2.b2+c3.b2+c4.b2+c5.b2<=2
   and c1.b3+c2.b3+c3.b3+c4.b3+c5.b3<=2
   and c1.b4+c2.b4+c3.b4+c4.b4+c5.b4<=2
   and c1.b5+c2.b5+c3.b5+c4.b5+c5.b5<=2 
   and c1.b1+c1.b2+c1.b3+c1.b4+c1.b5<=2
   and c2.b1+c2.b2+c2.b3+c2.b4+c2.b5<=2
   and c3.b1+c3.b2+c3.b3+c3.b4+c3.b5<=2
   and c4.b1+c4.b2+c4.b3+c4.b4+c4.b5<=2
   and c5.b1+c5.b2+c5.b3+c5.b4+c5.b5<=2
   and c1.b1+c2.b2+c3.b3+c4.b4+c5.b5<=2
   and c1.b5+c2.b4+c3.b3+c4.b2+c5.b1<=2
   and c1.b2+c2.b3+c3.b4+c4.b5<=2
   and c2.b1+c3.b2+c4.b3+c5.b4<=2
   and c1.b3+c2.b4+c3.b5<=2
   and c3.b1+c4.b2+c5.b3<=2
   and c1.b4+c2.b3+c3.b2+c4.b1<=2
   and c2.b5+c3.b4+c4.b3+c5.b2<=2
   and c1.b3+c2.b2+c3.b1<=2
   and c3.b5+c4.b4+c5.b3<=2
)
--列出符合要求的记录
select 
 combo
 from allcombo

WHERE RANK=1







本文转自baoqiangwang51CTO博客,原文链接:http://blog.51cto.com/baoqiangwang/514779,如需转载请自行联系原作者

相关文章
|
SQL 关系型数据库 MySQL
阿里云瑶池数据库SQL大赛获奖名单及参考答案
阿里云瑶池数据库SQL大赛获奖名单及参考答案
1259 0
阿里云瑶池数据库SQL大赛获奖名单及参考答案
|
SQL 机器学习/深度学习 人工智能
夺冠首届中文自动转SQL大赛,准确率高达92%,国防科大如何刷新纪录?
冠军方案根据自然语言提问生成简单 SQL 查询语句,已达到了 92.19% 的准确度,你能做到吗?
1223 0
夺冠首届中文自动转SQL大赛,准确率高达92%,国防科大如何刷新纪录?
|
SQL 关系型数据库 MySQL
阿里云慢SQL优化挑战大赛分析
阿里云慢SQL优化挑战赛,本次慢SQL优化挑战赛的题目全部来自于生产案例,将众多考察点揉合到一条SQL中,主要考虑了以下方面:表设计,索引优化,执行计划等优化知识,同时将历年生产中遇到的SQL优化案例进行总结分析,希望能够帮助到更多的开发者。
15068 1
|
SQL 安全 数据库
MS SQL Could not obtain information about Windows NT group/user &#39;domain\login&#39;, error code 0x5. [SQLSTATE 42000] (Error 15404)
最近碰到一个有趣的错误:海外的一台数据库服务器上某些作业偶尔会报错,报错信息如下所示: ---------------------------------------------------------------------------------------------------------...
1355 0
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
899 13
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。
623 9
|
SQL 存储 网络安全
关系数据库SQLserver 安装 SQL Server
【7月更文挑战第26天】
385 6
|
SQL Oracle 关系型数据库
MySQL、SQL Server和Oracle数据库安装部署教程
数据库的安装部署教程因不同的数据库管理系统(DBMS)而异,以下将以MySQL、SQL Server和Oracle为例,分别概述其安装部署的基本步骤。请注意,由于软件版本和操作系统的不同,具体步骤可能会有所变化。
1433 3