热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

8QueensinSmalltalk

试着用Pharo写了一个8皇后。算是练习。1Objectsubclass:#Queen2instanceVariableNames:'position'3class

试着用Pharo写了一个8皇后。算是练习。

1 Object subclass: #Queen
2 instanceVariableNames: position
3 classVariableNames: ‘‘
4 poolDictionaries: ‘‘
5 category: Queens!
6 !Queen commentStamp: TomZhao 10/15/2015 13:17 prior: 0!
7 Queen at: 1@1.!
8
9
10 !Queen methodsFor: accessing stamp: TomZhao 10/15/2015 13:22!
11 moveTo: aPoint
12 self position: aPoint.! !
13
14 !Queen methodsFor: accessing stamp: TomZhao 10/15/2015 13:41!
15 position
16 ^ position! !
17
18 !Queen methodsFor: accessing stamp: TomZhao 10/15/2015 13:17!
19 position: aPoint
20 position := aPoint! !
21
22
23 !Queen methodsFor: as yet unclassified stamp: TomZhao 10/15/2015 13:29!
24 meets: queen
25 |a b|
26 a := self position.
27 b := queen position.
28 ^(a x = b x) | (a y = b y) | ((a x - b x) abs = (a y - b y) abs).! !
29
30
31 !Queen methodsFor: testing stamp: TomZhao 10/15/2015 13:39!
32 isSafeWith: queens
33 ^queens allSatisfy: [ :queen | (self meets: queen) not ].! !
34
35 "-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- "!
36
37 Queen class
38 instanceVariableNames: ‘‘!
39
40 !Queen class methodsFor: as yet unclassified stamp: TomZhao 10/15/2015 09:42!
41 at: aPoint
42 "comment stating purpose of message"
43 | tmp |
44 tmp := self new.
45 tmp position: aPoint.
46 ^tmp.! !
47
48
49 Object subclass: #Queens
50 instanceVariableNames: size
51 classVariableNames: ‘‘
52 poolDictionaries: ‘‘
53 category: Queens!
54 !Queens commentStamp: TomZhao 10/15/2015 14:25 prior: 0!
55 Queens run: 6.!
56
57
58 !Queens methodsFor: acccessing stamp: TomZhao 10/15/2015 13:21!
59 size: anInteger
60 size := anInteger! !
61
62
63 !Queens methodsFor: as yet unclassified stamp: TomZhao 10/15/2015 14:39!
64 printSolution: queens
65 Transcript show: ($- join: (queens collect: [ :q | q position y ])); cr.! !
66
67
68 !Queens methodsFor: running stamp: TomZhao 10/15/2015 14:53!
69 run: anInteger
70 self size: anInteger.
71 self solve: 1 with: OrderedCollection new.
72 Transcript show: Game Over!!; cr.
73 ^self.! !
74
75 !Queens methodsFor: running stamp: TomZhao 10/15/2015 14:52!
76 solve: nRow with: queens
77 | q tmp |
78 q :=Queen at: nRow@1.
79 (1 to: size) do: [ :col |
80 q moveTo: nRow@col.
81 tmp := queens copy.
82 (q isSafeWith: tmp)
83 ifTrue: [
84 tmp add: q.
85 nRow = size
86 ifTrue:[self printSolution: tmp. ]
87 ifFalse:[self solve: (nRow+1) with: tmp.]]].! !
88
89 "-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- "!
90
91 Queens class
92 instanceVariableNames: ‘‘!
93
94 !Queens class methodsFor: as yet unclassified stamp: TomZhao 10/13/2015 17:01!
95 run: size
96
97 Queens new
98 run: size.
99 ^self.! !

 


推荐阅读
  • 解决Bootstrap DataTable Ajax请求重复问题
    在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ... [详细]
  • 本文介绍了如何使用 CMD 批处理脚本进行文件操作,包括将指定目录下的 PHP 文件重命名为 HTML 文件,并将这些文件复制到另一个目录。 ... [详细]
  • 本文介绍了如何在 ASP.NET 中设置 Excel 单元格格式为文本,获取多个单元格区域并作为表头,以及进行单元格合并、赋值、格式设置等操作。 ... [详细]
  • LDAP服务器配置与管理
    本文介绍如何通过安装和配置SSSD服务来统一管理用户账户信息,并实现其他系统的登录调用。通过图形化交互界面配置LDAP服务器,确保用户账户信息的集中管理和安全访问。 ... [详细]
  • 如果应用程序经常播放密集、急促而又短暂的音效(如游戏音效)那么使用MediaPlayer显得有些不太适合了。因为MediaPlayer存在如下缺点:1)延时时间较长,且资源占用率高 ... [详细]
  • 网络爬虫的规范与限制
    本文探讨了网络爬虫引发的问题及其解决方案,重点介绍了Robots协议的作用和使用方法,旨在为网络爬虫的合理使用提供指导。 ... [详细]
  • 本文介绍了 AngularJS 中的 $compile 服务及其用法,通过示例代码展示了如何使用 $compile 动态编译和链接 HTML 元素。 ... [详细]
  • 两个条件,组合控制#if($query_string~*modviewthread&t(&extra(.*)))?$)#{#set$itid$1;#rewrite^ ... [详细]
  • 解决Win10下MySQL连接问题:Navicat 2003无法连接到本地MySQL服务器(10061)
    本文介绍如何在Windows 10环境下解决Navicat 2003无法连接到本地MySQL服务器的问题,包括启动MySQL服务和检查配置文件的方法。 ... [详细]
  • 本文详细介绍了如何利用Duilib界面库开发窗体动画效果,包括基本思路和技术细节。这些方法不仅适用于Duilib,还可以扩展到其他类似的界面开发工具。 ... [详细]
  • Spark中使用map或flatMap将DataSet[A]转换为DataSet[B]时Schema变为Binary的问题及解决方案
    本文探讨了在使用Spark的map或flatMap算子将一个数据集转换为另一个数据集时,遇到的Schema变为Binary的问题,并提供了详细的解决方案。 ... [详细]
  • 第二十五天接口、多态
    1.java是面向对象的语言。设计模式:接口接口类是从java里衍生出来的,不是python原生支持的主要用于继承里多继承抽象类是python原生支持的主要用于继承里的单继承但是接 ... [详细]
  • 解决Parallels Desktop错误15265的方法
    本文详细介绍了在使用Parallels Desktop时遇到错误15265的多种解决方案,包括检查网络连接、关闭代理服务器和修改主机文件等步骤。 ... [详细]
  • 解决 Windows Server 2016 网络连接问题
    本文详细介绍了如何解决 Windows Server 2016 在使用无线网络 (WLAN) 和有线网络 (以太网) 时遇到的连接问题。包括添加必要的功能和安装正确的驱动程序。 ... [详细]
  • 使用Jsoup解析并遍历HTML文档时,该库能够高效地生成一个清晰、规范的解析树,即使源HTML文档存在格式问题。Jsoup具备强大的容错能力,能够处理多种异常情况,如未闭合的标签等,确保解析结果的准确性和完整性。 ... [详细]
author-avatar
美君朝龙冰盛
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有