Snowdream
posts - 403, comments - 310, trackbacks - 0, articles - 7
BlogJava
::
首页
::
新随笔
::
联系
::
聚合
::
管理
1.30 Java notes
Posted on 2007-04-22 20:23
ZelluX
阅读(125)
评论(0)
编辑
收藏
所属分类:
OOP
2007-01-30 23:59:59
本来想在晚上把连连看的棋盘生成部分完成了的,不过貌似做不到了
算法是每次随机填入一个元素,然后按顺序找到能和它连接的一个空格填入同一个元素(如果找不到就回溯),填下一个元素。
也就是说填入的位置中有一个随机数,另一个按有序表1..n生成,这个算法应该能保证解的可行性并能覆盖所有的情况吧(再把1..n元素的位置随机排一下应该能覆盖了)
每次在填数前先判断是否有无法被连接的空格,这个剪枝效果很好。
还想到一种算法,先随机排满,然后消去所有能够连接到的对子,剩下的随机交换位置,再次消去能够连接的对子,直到全部消去为止。貌似这个算法不错,复杂度应该是O(k*n*m),n,m为行列,k为平均每次为了消去对子所需的交换次数,和随机序列的好坏有关,速度应该相当快了。
细节方面有个判断对子是否连接的函数,这个函数我是通过三次“扩张”解决的,首先从其中一个位置出发,向四周扩张,直到碰到“障碍物”;第二次从上一次扩张到的每个点出发,再次向四周扩张;然后再做一次就行。然后就只要判断另外一个棋子是否在这个位置的“殖民地”上就行(呵呵,Thinking in Zerg,恩)。当然棋盘的周围还要有一圈无障碍的空间。
小结
1. tempMap = (int[][])(map.clone());
并不是把map[][]的所有元素赋值给tempMap,但是(tempMap == map)的结果又是false,很奇怪
后来只好用两重循环写了个
现在分析一下
tempMap -< reference[] -< int[][]
reference -< int[]
map[][]相当于一个指向int[]的reference数组,而clone的作用可能仅仅把每一个reference赋值给了tempMap,因此tempMap本身的reference并没有变,因此tempMap != map;但是改动了tempMap中的某个元素以后,由于reference[]指向的地址和map[][]的地址一样,因此map数组中的元素也会变动
不知道这么理解对不对
2. Java 里方法不能嵌套?比如
Board() {
void DFS(int step) {
}
}
这样貌似不可以?
新用户注册
刷新评论列表
只有注册用户
登录
后才能发表评论。
网站导航:
博客园
IT新闻
Chat2DB
C++博客
博问
管理
相关文章:
为什么Python中的self必须保留?
Python中inner function的binding处理
C# From a Java Programmer's Perspective
Singleton模式与双检测锁定(DCL)
C# 学习笔记 (1)
Java Puzzler - 数值处理中容易犯的错误
Java3D 入门笔记 (1)
Java 的类库真是方便啊
Java泛型中的? super T语法
Project3 成功转移到Ubuntu
Powered by:
BlogJava
Copyright © ZelluX
日历
<
2007年4月
>
日
一
二
三
四
五
六
25
26
27
28
29
30
31
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
1
2
3
4
5
常用链接
我的随笔
我的评论
我的参与
最新评论
留言簿
(21)
给我留言
查看公开留言
查看私人留言
随笔分类
(390)
Algorithm(57)
C/C++(39)
Courses(15)
Economics(2)
Laboratory(25)
Linux(47)
Mathematics(12)
OOP(89)
Scripting(19)
Security(3)
System(28)
Web(10)
书、电影、音乐(11)
其他(14)
点滴(19)
随笔档案
(389)
2009年12月 (1)
2009年4月 (1)
2009年3月 (4)
2009年2月 (2)
2009年1月 (2)
2008年11月 (1)
2008年10月 (9)
2008年9月 (1)
2008年7月 (2)
2008年6月 (4)
2008年5月 (12)
2008年4月 (18)
2008年3月 (7)
2008年2月 (33)
2008年1月 (19)
2007年12月 (8)
2007年11月 (14)
2007年10月 (24)
2007年9月 (18)
2007年8月 (28)
2007年7月 (33)
2007年6月 (26)
2007年5月 (30)
2007年4月 (92)
文章档案
(7)
2007年7月 (2)
2007年5月 (4)
2007年4月 (1)
相册
Illustration
15ers
jonathan的BLOG
Right There...
宙斯鱼的小鱼缸
小鲍的世界
简单幸福
逃遁的Persephone
阿缪尔的锦瑟
风之语的BLOG
友情链接
(04CS) ljh
(05CS) 小菜虎的窝
(06CS) FreePeter
(06SS) Overboming
(06SS) Sherry
(06SS) 十指飞扬
(06SS) 银色子弹
luohandsome的专栏
平淡是真——啃啃不老阁
收藏夹
[ADN.cn]Library
Debian学习笔记
Dictionary of Algorithms and Data Structures
Gollum
Lex&Yacc
Max On Java
techInterview Discussion
核桃仁
程序员面试题精选100题
铁手
搜索
积分与排名
积分 - 334683
排名 - 168
最新随笔
1. 新博客
2. 慎用xen的make world...
3. 内存模型相关的资料
4. 安全方面的经典论文:A Logic of Authentication
5. Lock-Free 算法的几个链接
6. 10 Papers Every Programmer Should Read
7. PieTTY中按Ctrl+S导致挂起的问题解决
8. Finding and Reproducing Heisenbugs in Concurrent Programs
9. Ubuntu 8.10 浏览网页不稳定的解决方法
10. [zz]苏南经济模式兴衰亲历记
最新评论
1. re: C/C++中的序列点
说的太好了,解决我长久的困扰!
--除美灭日平韩
2. re: 原来GCC是支持尾递归的递推优化的
评论内容较长,点击标题查看
--darkhorse
3. re: Arch下配置samba服务
我按照你的方法,安装了SAMBA,但是 /etc/rc.d/samba start 启动不了samba服务。提示不存在这个文件或目录的,怎么办?
--zhangbear
4. re: [zz]LKM Rootkits on Linux x86 v2.6
rhel 5 系列 安装了 Xen 内核, 怎么rootkit xen kernel 呢?
--消息
5. re: CLRS 习题 16.2-6 部分背包问题的O(n)算法
@ynnej
T(n)=2T(n/2)+O(n) 才是 nlgn 注意其中有一个2
--荒废庭院
阅读排行榜
1. [zz]vim+ctags+taglist插件安装使用(18305)
2. memcpy函数代码分析(9372)
3. [zz]Zotero与Endnote的互相导入(8760)
4. BNF 文法 (1) - 语法树 | 二义性的解决(8228)
5. Java泛型中的? super T语法(6557)
评论排行榜
1. C# 学习笔记 (1)(14)
2. Windows - QQ、网页Flash视频无声音的解决方法(14)
3. URAL 1011(10)
4. 《编程之美》上的一道题目的讨论(8)
5. Singleton模式与双检测锁定(DCL)(7)