分享好友 编程语言首页 频道列表

数据结构--用Objective-C简单实现的数据结构:栈

Objective-C  2023-02-09 10:100

前言:最近在学习数据结构,这里用Objective-C简单实现了一下栈。用Objective-C确实好容易,因为我使用了Cocoa框架提供了NSMutableArray作为存储元素的集合,操作集合元素很方便。

只不过,下面这种实现方法可能不是最优化的,因为NSMutableArray不是最轻量级的集合容器。我现在还不知道如何写出最优化的栈实现,同时还需要满足这一个需求:存储的元素是OC对象 。

 

使用NSMutableArray作为存储元素的集合的优点:类似C语言实现栈的链式存储结构,就不会和C语言数组那样会出现溢出(或者是数组下标越界)的情况。

 

Objective-C源码:

文件StackForNSObject.h:

 1 #import <Foundation/Foundation.h>
 2 
 3 // 只要参数是一个id类型的block
 4 typedef void (^StackBlock)(id objc);
 5 
 6 @interface StackForNSObject : NSObject
 7 
 8 // 入栈
 9 -(void)push:(id)objet;
10 // 出栈
11 -(id)popTopElement;
12 // 返回栈顶元素
13 -(id)TopElement;
14 // 是否为空
15 -(BOOL)isEmpty;
16 // 栈的长度
17 -(NSInteger)stackLength;
18 // 遍历,从栈底开始遍历
19 -(void)traversalElementFromBottom:(StackBlock)block;
20 // 从顶部开始遍历
21 -(void)traversalElementFromtop:(StackBlock)block;
22 // 所有元素出栈,一边出栈一边返回元素
23 -(void)traversalElementPopStack:(StackBlock)block;
24 // 清空
25 -(void)removeAllObjects;
26 // 返回栈顶元素
27 -(id)topElemet;
28 
29 @end

文件:StackForNSObject.m

  1 #import "StackForNSObject.h"
  2 
  3 @interface StackForNSObject ()
  4 
  5 /** maxSize */
  6 //@property (nonatomic,assign)NSInteger maxSize;
  7 
  8 // 有入栈就有出栈的时候,使用强引用,就要记得释放引用
  9 /** NSMutableArray */
 10 @property (nonatomic,strong)NSMutableArray *stackArray;
 11 
 12 /** top of stack */
 13 @property (nonatomic,assign)NSInteger top;
 14 
 15 /** stack */
 16 //@property (nonatomic,weak)StackBlock stackBlock;
 17 
 18 @end
 19 
 20 @implementation StackForNSObject
 21 
 22 // 初始化
 23 
 24 // 入栈
 25 -(void)push:(id)objet{
 26     [self.stackArray addObject:objet];
 27 }
 28 
 29 // 出栈
 30 -(id)popTopElement{
 31     id objc = [self.stackArray lastObject];
 32     [self.stackArray removeLastObject];
 33     return objc;
 34 }
 35 
 36 // 返回栈顶元素
 37 -(id)TopElement{
 38     return [self.stackArray lastObject];
 39 }
 40 
 41 // 是否为空
 42 -(BOOL)isEmpty{
 43     return self.stackArray.count;
 44 }
 45 
 46 // 栈的长度
 47 -(NSInteger)stackLength{
 48     return self.stackArray.count;
 49 }
 50 
 51 // 从底部开始遍历
 52 -(void)traversalElementFromBottom:(StackBlock)block{
 53     NSEnumerator *objc = [self.stackArray objectEnumerator];
 54     for (id element in objc) {
 55         block(element);
 56     }
 57 }
 58 
 59 // 从顶部开始遍历
 60 -(void)traversalElementFromtop:(StackBlock)block{
 61     // 先获取存储元素的个数
 62     NSInteger count = self.stackArray.count;
 63     for (NSInteger i = count; i > 0; i --) {
 64         // 处理最后一个元素
 65         block([self.stackArray objectAtIndex:i]);
 66     }
 67 }
 68 
 69 // 所有元素出栈,同时遍历
 70 -(void)traversalElementPopStack:(StackBlock)block{
 71     // 先获取存储元素的个数
 72     NSInteger count = self.stackArray.count;
 73     for (NSInteger i = count; i > 0; i --) {
 74         // 处理最后一个元素
 75         block(self.stackArray.lastObject);
 76         [self.stackArray removeLastObject];
 77     }
 78 }
 79 
 80 // 返回栈顶元素
 81 -(id)topElemet{
 82     return self.stackArray.lastObject;
 83 }
 84 
 85 // 清空
 86 -(void)removeAllObjects{
 87     [self.stackArray removeAllObjects];
 88 }
 89 
 90 #pragma mark - 懒加载
 91 -(NSMutableArray*)stackArray{
 92     if (_stackArray == nil) {
 93         _stackArray = [NSMutableArray array];
 94     }
 95     return _stackArray;
 96 }
 97 -(NSInteger)top{
 98     _top = self.stackArray.count;
 99     return _top;
100 }
101 
102 #pragma mark - 不存在该对象的时候,自动清空
103 - (void)dealloc{
104     [self.stackArray removeAllObjects];
105 }
106 
107 @end

测试代码:

数据结构--用Objective-C简单实现的数据结构:栈

该源码本人备份在百度云上了:链接: http://pan.baidu.com/s/1pKPrnsR 密码: eug9

 

查看更多关于【Objective-C】的文章

展开全文
相关推荐
反对 0
举报 0
评论 0
图文资讯
热门推荐
优选好物
更多热点专题
更多推荐文章
《黑马程序员》 category分类的使用(Objective - c语法)
分类的作用:在不改变原来类的基础上,可以给类增加一些方法。使用注意 : ①  分类只能增加方法,不可以增加成员变量                ②  分类的方法在实现中可以访问成员变量,不过成员变量必须手动实现。               

0评论2023-03-16482

Objective-C Runtime(转)
博主地址: http://yulingtianxia.com/blog/2014/11/05/objective-c-runtime/曾经觉得Objc特别方便上手,面对着 Cocoa 中大量 API,只知道简单的查文档和调用。还记得初学 Objective-C 时把[receiver message]当成简单的方法调用,而无视了“发送消息”这句话

0评论2023-03-08434

Objective-C利用协议实现回调函数
实现一个显示文字为测试的视图,然后经过3秒钟测试文字变为回调函数文字。相应的截图如下:  实现的代码如下:定义协议:#import UIKit/UIKit.h @protocol NoteDelegate //回调函数 -(void)messageCallBack:(NSString *)string; @end 调用协议:#impor

0评论2023-02-10480

刨根问底Objective-C Runtime(1)- Self & Super
  刨根问底Objective-C Runtime(1)- SelfSuper - Chun Tips专注iOS开发 刨根问底Objective-C Runtime(1)- SelfSuper前言关于Objective-C Runtime一篇好的文档 : Understanding the Objective-C Runtime译文地址为: http://blog.cocoabit.com/blog/2

0评论2023-02-10566

Objective-C利用协议实现回调函数
实现一个显示文字为测试的视图,然后经过3秒钟测试文字变为回调函数文字。相应的截图如下: 实现的代码如下:定义协议:#import UIKit/UIKit.h @protocol NoteDelegate//回调函数-(void)messageCallBack:(NSString *)string;@end  调用协议:#import Founda

0评论2023-02-10750

Objective-c开发中混合使用ARC
首选“Compile Sources”的位置:选中工程-TARGETS-相应的target然后选中右侧的“Build Phases”,向下就找到“Compile Sources”了。如何在未使用arc的工程中引入一个使用了arc特性的文件:对相应的文件添加:-fobjc-arc参数如何在arc工程中引用未使用arc的文件

0评论2023-02-10774

Objective C运行时(runtime)技术总结,好强大的runtime
前言:         Objective C的runtime技术功能非常强大,能够在运行时获取并修改类的各种信息,包括获取方法列表、属性列表、变量列表,修改方法、属性,增加方法,属性等等,本文对相关的几个要点做了一个小结。目录:(1)使用class_replaceMethod/cla

0评论2023-02-09994

Programming With Objective-C---- Introduction ---- Objective-C 学习(一)
a:link { color: rgba(88, 114, 210, 1); text-decoration: none }a:visited { color: rgba(88, 114, 210, 1); text-decoration: none }a:hover { color: rgba(173, 189, 248, 1); text-decoration: none }a:active { color: rgba(0, 0, 255, 1); text-decora

0评论2023-02-09863

设计模式之开放-封闭原则(引申出Objective-C中继承、Category、Protocol三者的区别,这点面试常问)
开放封闭原则(OCP原则The Open-Closed Principle)是面向对象的核心设计所在。它是说,软件开发实体(类、模块、函数等)应该可以扩展,但是不能修改。这个原则有两个特征,一个是说“对于扩展是开放的”,另一个是说“对于更改是封闭的”。我们在编写任何ap

0评论2023-02-09395

Singletons in Objective-C
BackgroundSingletons classes are an important concept to understand because they exhibit an extremtely useful design pattern.This idea is used throughout the iPhone SDK, for example, UIApplication has a method called sharedApplication which

0评论2023-02-09522

Objective-C运行时编程 - 实现自动化description方法的思路及代码示例
发布自米高 | Michael - 博客园,源地址:http://www.cnblogs.com/michaellfx/p/4232205.html,转载请注明。基础实现性能优化参考关键字:Objective-COCdescription函数自动打印属性及属性值运行时枚举成员变量基础实现使用NSLog或po,Xcode默认调用对象的des

0评论2023-02-09866

Objective-C 学习笔记 - part 11 - 错误处理
Object-C 提供类似 Java / C++风格的错误处理模型,当使用 -fobjc-exceptions 开关(gcc3.3)时,它可以工作,但是只限于 OS X v10.3 以后的版本,之前的版本并不提供这一支持。使用错误捕获的原则与其它语言类似:你不能用它来当作正常的处理流的判断条件

0评论2023-02-09893

objective-c 字符串基本操作
1.定义一个字符串a, 截取a 的某一个部分,复制给b, b必须是int型NSString *a = @"1.2.30"; int b= [[a substringWithRange:NSMakeRange(4,2)] intValue]; NSLog(@"a:%@n",a); NSLog(@"b:%d",b); 解析如下:substringWithRange: 专门截取字符串的一块肉NSMakeR

0评论2023-02-09602

Objective-C 程序设计(第六版)第十一章习题答案
1. 1 #import "Fraction.h" 23 @interface Fraction (MathOps) 45 - (Fraction *) add: (Fraction *) f; 67 - (Fraction *) mul: (Fraction *) f; 89 - (Fraction *) sub: (Fraction *) f;10 11 - (Fraction *) div: (Fraction *) f;12 13 - (Fraction *) inv

0评论2023-02-09476

Objective-C与C style语言的简单类比
1. 关于Objc中函数调用类比[_lblHelloWorld setHidden:![_lblHelloWorld isHidden]];类比为: _lblHelloWorld.setHidden(!(_lblHelloWorld.isHidden()));Tip: objc中的boolean值为YES和NO,而不是True or False  -(void) helloWorld:(BOOL)isHelloWorld{}

0评论2023-02-09682

Objective-C中.h文件、.m文件中@interface、@synthesize及其它
很多开发iOS好几年的老鸟,可能都不太分的清.h文件和.m文件里各种结构的用途和区别。最近仔细研究了一下,写一篇文章记下来。 一般的,写一个Class的时候,经常是这种格式(以UIViewController为例):.h文件:@interface ClassName{NSString* _value1;}@pro

0评论2023-02-09878

Objective - C block
  block是从ios4开始引进的新东西,声明一个block就好比声明一个方法的指针。下面声明一个block,这个block是返回值为空,它有两个参数:void( ~myBlock)(NSString *str1,int val);  为了声明一种类型的block,可以这样写:typedef void(~MyBlockType)(NSS

0评论2023-02-09468

更多推荐