Swift - 几种使用数组的数据存储模型
在iOS游戏开发中,比如2048游戏。有时会需要存储N×N数组的数据模型(如3×3,4×4等)。这里我们演示了三种实现方式,分别是:一维数组、仿二维数组、自定义二维数组(即矩阵结构)。
功能是根据传入维度初始化数组,同时提供设置值和打印输出所有值的功能,判断数组是否已满(全不为0),以及目前空位的坐标集。
|
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
|
import Foundationclass GameModel{ var dimension:Int = 0 var tiles:Array<Int> init(dimension:Int) { self.dimension = dimension self.tiles = Array<Int>(count:self.dimension*self.dimension, repeatedValue:0) } //找出空位置 func emptyPositions()-> [Int] { var emptytiles = Array<Int>() //var index:Int for i in 0..<(dimension*dimension) { if(tiles[i] == 0) { emptytiles.append(i) } } return emptytiles } //位置是否已满 func isFull()-> Bool { if(emptyPositions().count == 0) { return true } return false } //输出当前数据模型 func printTiles() { println(tiles) println("输出数据模型数据") var count = tiles.count for var i=0; i<count; i++ { if (i+1) % Int(dimension) == 0 { println(tiles[i]) } else { print("\(tiles[i])\t") } } println("") } //如果返回 false ,表示该位置 已经有值 func setPosition(row:Int, col:Int, value:Int) -> Bool { assert(row >= 0 && row < dimension) assert(col >= 0 && col < dimension) //3行4列,即 row=2 , col=3 index=2*4+3 = 11 //4行4列,即 3*4+3 = 15 var index = self.dimension * row + col var val = tiles[index] if(val > 0) { println("该位置(\(row), \(col))已经有值了") return false } tiles[index] = value return true }} |
2,使用二维数组实现
|
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
|
import Foundationclass GameModelBA{ var dimension:Int = 0 var tiles:Array<Array<Int>> //由外部来传入维度值 init(dimension:Int) { self.dimension = dimension self.tiles = Array(count:self.dimension, repeatedValue:Array(count:self.dimension, repeatedValue:0)) } //找出空位置 func emptyPositions()-> [Int] { var emptytiles = Array<Int>() //var index:Int for row in 0..<self.dimension { for col in 0..<self.dimension { if(tiles[row][col] == 0) { emptytiles.append(tiles[row][col]) } } } return emptytiles } //如果返回 false ,表示该位置 已经有值 func setPosition(row:Int, col:Int, value:Int) -> Bool { assert(row >= 0 && row < dimension) assert(col >= 0 && col < dimension) var val = tiles[row][col] if(val > 0) { println("该位置(\(row), \(col))已经有值了") return false } printTiles() //tiles[row][col] = value var rdata = Array(count:self.dimension, repeatedValue:0) for i in 0..<self.dimension { rdata[i] = tiles[row][i] } rdata[col] = value tiles[row] = rdata return true } //位置是否已满 func isFull()-> Bool { if(emptyPositions().count == 0) { return true } return false } //输出当前数据模型 func printTiles() { println(tiles) println("输出数据模型数据") var count = tiles.count for row in 0..<self.dimension { for col in 0..<self.dimension { print("\(tiles[row][col])\t") } println("") } println("") }} |
3,使用自定义二维数组(即矩阵结构)
|
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
import Foundation//自定义矩阵数据结构struct Matrix { let rows: Int, columns: Int var grid: [Int] init(rows: Int, columns: Int) { self.rows = rows self.columns = columns grid = Array(count: rows * columns, repeatedValue: 0) } func indexIsValidForRow(row: Int, column: Int) -> Bool { return row >= 0 && row < rows && column >= 0 && column < columns } subscript(row: Int, column: Int) -> Int { get { assert(indexIsValidForRow(row, column: column), "超出范围") return grid[(row * columns) + column] } set { assert(indexIsValidForRow(row, column: column), "超出范围") grid[(row * columns) + column] = newValue } }}class GameModelMatrix{ var dimension:Int = 0 var tiles:Matrix //由外部来传入维度值 init(dimension:Int) { self.dimension = dimension self.tiles = Matrix(rows: self.dimension, columns: self.dimension) } //找出空位置 func emptyPositions()-> [Int] { var emptytiles = Array<Int>() //var index:Int for row in 0..<self.dimension { for col in 0..<self.dimension { var val = tiles[row,col] if(val == 0) { emptytiles.append(tiles[row, col]) } } } return emptytiles } //如果返回 false ,表示该位置已经有值 func setPosition(row:Int, col:Int, value:Int) -> Bool { assert(row >= 0 && row < dimension) assert(col >= 0 && col < dimension) var val = tiles[row,col] if(val > 0) { println("该位置(\(row), \(col))已经有值了") return false } printTiles() tiles[row, col] = value printTiles() return true } //位置是否已满 func isFull()-> Bool { if(emptyPositions().count == 0) { return true } return false } //输出当前数据模型 func printTiles() { println(tiles) println("输出数据模型数据") for row in 0..<self.dimension { for col in 0..<self.dimension { print("\(tiles[row, col])\t") } println("") } println("") }} |
Swift - 几种使用数组的数据存储模型的更多相关文章
- Swift - 使用NSUserDefaults来进行本地数据存储
NSUserDefaults适合存储轻量级的本地客户端数据,比如记住密码功能,要保存一个系统的用户名.密码.使用NSUserDefaults是首选.下次再登陆的时候就可以直接从NSUserDefaul ...
- Android核心技术Intent和数据存储篇
女孩:上海站到了? 男孩:嗯呢?走向世界~ 女孩:Intent核心技术和数据存储技术? 男孩:对,今日就讲这个~ Intent是各个组件之间用来进行通信的,Intent的翻译为"意图&quo ...
- Android开发工程师文集-提示框,菜单,数据存储,组件篇
提示框,菜单,数据存储,组件篇 Toast Toast.makeText(context, text, 时间).show(); setDuration();//设置时间 setGravity();// ...
- Android之ListView,AsyncTask,GridView,CardView,本地数据存储,SQLite数据库
版权声明:未经博主允许不得转载 补充 补充上一节,使用ListView是用来显示列表项的,使用ListView需要两个xml文件,一个是列表布局,一个是单个列表项的布局.如我们要在要显示系统所有app ...
- 数据存储与访问之——SharedPreferences
使用SharedPreferences(保存用户偏好参数)保存数据, 当我们的应用想要保存用户的一些偏好参数,比如是否自动登陆,是否记住账号密码,是否在Wifi下才能 联网等相关信息,如果使用数据库的 ...
- Android 数据存储五种方式
1.概述 Android提供了5种方式来让用户保存持久化应用程序数据.根据自己的需求来做选择,比如数据是否是应用程序私有的,是否能被其他程序访问,需要多少数据存储空间等,分别是: ① 使用Shared ...
- iOS开发 - OC - 实现本地数据存储的几种方式一
iOS常用的存储方式介绍 在iOS App开发过程中经常需要操作一些需要持续性保留的数据,比如用户对于App的相关设置.需要在本地缓存的数据等等.本文针对OC中经常使用的一下存储方式做了个整理. 常用 ...
- Android数据存储五种方式总结
本文介绍Android平台进行数据存储的五大方式,分别如下: 1 使用SharedPreferences存储数据 2 文件存储数据 3 SQLite数据库存储数据 4 使用Cont ...
- android 数据存储的几种方式
总体的来讲,数据存储方式有三种:一个是文件,一个是数据库,另一个则是网络.其中文件和数据库可能用的稍多一些,文件用起来较为方便,程序可以自己定义格式:数据库用起稍烦锁一些,但它有它的优点,比如在海量数 ...
随机推荐
- c语言‘\0’ ,‘0’, “0” ,0之间的区别
首先比较一下‘\0’和‘0’的区别.有一个共同点就是它们都是字符,在c语言中,字符是按其所对应的ASCII码来存储的,一个字符占一个字节.请翻开你的ASCII字符集表吧,一般在你的C语言教材的附录上, ...
- javascript语言精粹:继承
继承提供了2个有用的任务: 1.代码重用 2.引入了一套类型系统的规范,因为程序员无需编写显示类型转换的代码,他们的工作量将大大减轻.这是一件很好的事情,应为类型转换会丧失类型系统在安全上的优势. 在 ...
- ThinkPHP 3.1.2 URL<1>
# # ThinkPHP 3.1.2 URL 本节课大纲: 一.URL规则 1.默认是区分大小写的 2.如果我们不想区分大小写可以改配置文件 'URL_CASE_INSENSITIVE'=>tr ...
- muduo 与 libevent2 吞吐量对照
libevent 是一款很好用的 C 语言网络库,它也採用 Reactor 模型,正好能够与 muduo 做一对照. 本文用 ping pong 測试来对照 muduo 和 libevent2 的吞吐 ...
- 离散傅立叶变换与快速傅立叶变换(DFT与FFT)
自从去年下半年接触三维重构以来,听得最多的词就是傅立叶变换,后来了解到这个变换在图像处理里面也是重点中的重点. 本身自己基于高数知识的理解是傅立叶变换是将一个函数变为一堆正余弦函数的和的变换.而图像处 ...
- 为学Linux,我看了这些书
为学Linux,我看了这些书 去年开始,抱着学习的态度开始了我的Linux学习,到现在,差不多一年了,收获很多,不敢说精通Linux,但是,还是对得起"略懂"这两个字的.这一年 ...
- BZOJ 3477: [Usaco2014 Mar]Sabotage( 二分答案 )
先二分答案m, 然后对于原序列 A[i] = A[i] - m, 然后O(n)找最大连续子序列和, 那么此时序列由 L + mx + R组成. L + mx + R = sum - n * m, s ...
- Python 第六篇(上):面向对象编程初级篇
面向:过程.函数.对象: 面向过程:根据业务逻辑从上到下写垒代码! 面向过程的编程弊:每次调用的时候都的重写,代码特别长,代码重用性没有,每次增加新功能所有的代码都的修改!那有什么办法解决上面出现的弊 ...
- 1 #安装php
#安装php #备注:php5..3以后的版本源码不需要打php-fpm补丁,该补丁已经集成进5..3中强制启用fastcgi. [root@dba01 nginx-]# cd [root@dba01 ...
- linux popen函数
描述 popen() 函数 用 创建管道 的 方式启动一个 进程, 并调用 shell. 因为 管道是被定义成单向的, 所以 type 参数 只能定义成 只读或者 只写, 不能是 两者同时, 结果流也 ...