objectivec mysql_Objective-C语法之NSSet和NSMutableSet

NSSet和NSMutableSet是无序的, 但是它保证数据的唯一性。当插入相同的数据时,不会有任何效果。从内部实现来说是hash表,所以可以常数时间内查找一个数据。

06c5177d267d86c53e309eb357e3bbf4.png

1、NSSet的使用 [NSSet setWithSet:(NSSet *)set]; 用另外一个set对象构造

[NSSet setWithArray:(NSArray *)array];用数组构造

[NSSet setWithObjects:...]:创建集合对象,并且初始化集合中的数值,结尾必需使用nil标志。

[set count] ; 得到这个结合对象的长度。

[set containsObject:...]: 判断这个集合中是否存在传入的对象,返回Bool值。

[set objectEnumerator]: 将集合放入迭代器。

[enumerator nextObject]:得到迭代器中的下一个节点数据,使用while遍历这个迭代器,方可遍历集合对象中的对象。

[set isEqualToSet:objset]:判断两个集合是否完全相等,返回Bool值。

[set isSubsetOfSet:objset]:判断集合中的所有数据是否都相等与objeset集合中,返回Bool值。

[set allObjects];

示例代码:

1.1 以NSArray构造set

NSArray *array = [[NSArray alloc] initWithObjects:@"对象abc",@"rongfzh", @"totogo2010",nil];

NSSet *set3 = [NSSet setWithArray:array];

NSLog(@"%@", set3);

打印:

2012-07-10 09:39:02.015 objectiveC[720:403] {(

rongfzh,

"\U5bf9\U8c61abc",

totogo2010

)}

1.2 set的一些比较方法的使用。

int main(int argc, const char * argv[])

{

@autoreleasepool {

NSSet *set = [NSSet setWithObjects:@"25",@"age",@"张三",@"name",@"男",nil];

NSSet *set1 = [NSSet setWithObjects:@"25",@"age",@"张三",@"name",@"男",@"性别",nil];

NSLog(@"set count:%lu", [set count]);

//判断是否含有age字符串

if([set containsObject:@"age"]) {

NSLog(@"set包含age");

}

//判断set 是否等于set1

if ([set isEqualToSet:set1]) {

NSLog(@"set 等于 set1");

}

//判断set是否是否是set1的子集合

if ([set isSubsetOfSet:set1]) {

NSLog(@"set isSubsetOfSet set1");

}

//获取所有set对象

NSArray *array = [set allObjects];

NSLog(@"array:%@", array);

//迭代遍历

NSEnumerator *enumerator = [set objectEnumerator];

for (NSObject *object in enumerator) {

NSLog(@"set1里的对象:%@", object);

}

}

return 0;

}

打印结果:

2012-07-10 09:50:32.018 objectiveC[939:403] set count:5

2012-07-10 09:50:32.020 objectiveC[939:403] set包含age

2012-07-10 09:50:32.021 objectiveC[939:403] set isSubsetOfSet set1

2012-07-10 09:50:32.023 objectiveC[939:403] array:(

age,

25,

"\U7537",

"\U5f20\U4e09",

name

)

2012-07-10 09:50:32.027 objectiveC[939:403] set1里的对象:age

2012-07-10 09:50:32.028 objectiveC[939:403] set1里的对象:25

2012-07-10 09:50:32.028 objectiveC[939:403] set1里的对象:男

2012-07-10 09:50:32.029 objectiveC[939:403] set1里的对象:张三

2012-07-10 09:50:32.029 objectiveC[939:403] set1里的对象:name

2、NSMutableSet的使用

NSMutableSet继承NSSet,它可以使用NSSet的方法。

[NSMutableSet setWithCapacity:6]:创建可变集合对象,并且初始化长度为6。

[set addObject: obj] : 向集合中动态的添加对象。

[set removeObject:obj]:删除集合中的一个对象。

[set removeAllObjects]:删除集合中的所有对象。

[set unionSet:obj]:向集合中添加一个obj集合的所有数据。

[set minusSet:obj]:向集合中删除一个obj集合的所有数据。

[set intersectSet]:向集合中删除一个不包含obj集合的所有数据。

示例代码:

int main(int argc, const char * argv[])

{

@autoreleasepool {

NSMutableSet *muSet = [NSMutableSet setWithCapacity:6];

[muSet addObject:@"对象1"];

NSSet *set = [NSSet setWithObjects:@"对象2",@"对象3", @"被企鹅咬了一口", nil];

//添加set数据

[muSet unionSet:set];

for (NSObject *object in muSet) {

NSLog(@"all nuSet:%@",object);

}

NSSet *set1 = [NSSet setWithObjects:@"对象2",@"对象3", nil];

//在muSet中删除包含set1总数据

[muSet minusSet:set1];

for (NSObject *object in muSet) {

NSLog(@"after minusSet:%@",object);

}

}

return 0;

}

打印结果:

2012-07-10 10:09:08.194 objectiveC[1156:403] all nuSet:对象1

2012-07-10 10:09:08.196 objectiveC[1156:403] all nuSet:被企鹅咬了一口

2012-07-10 10:09:08.196 objectiveC[1156:403] all nuSet:对象2

2012-07-10 10:09:08.197 objectiveC[1156:403] all nuSet:对象3

2012-07-10 10:09:08.198 objectiveC[1156:403] after minusSet:对象1

2012-07-10 10:09:08.198 objectiveC[1156:403] after minusSet:被企鹅咬了一口

著作权声明:本文由http://blog.csdn.net/totogo2010/原创,欢迎转载分享。请尊重作者劳动,转载时保留该声明和作者博客链接,谢谢!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Objective-C是一面向对象的编程语言它是基于C语言的扩展虽然Objective-C本身并没有提供红黑树的实现,但可以通过使用Foundation框架中的NSSet类来实现类似红黑树的功能[^2]。 NSSet是Foundation框架中的一个集合类,它可以存储一组无序且唯一的对象。NSSet内部的实现可能使用了红黑树等数据结构来提高查询速度。 下面是一个使用Objective-C实现红黑树的示例代码: ```objective-c #import <Foundation/Foundation.h> @interface RedBlackTree : NSObject - (void)insertValue:(NSNumber *)value; - (BOOL)containsValue:(NSNumber *)value; @end @implementation RedBlackTree { NSMutableSet *_set; } - (instancetype)init { self = [super init]; if (self) { _set = [NSMutableSet set]; } return self; } - (void)insertValue:(NSNumber *)value { [_set addObject:value]; } - (BOOL)containsValue:(NSNumber *)value { return [_set containsObject:value]; } @end int main(int argc, const char * argv[]) { @autoreleasepool { RedBlackTree *tree = [[RedBlackTree alloc] init]; [tree insertValue:@5]; [tree insertValue:@3]; [tree insertValue:@8]; NSLog(@"Contains 5: %@", [tree containsValue:@5] ? @"Yes" : @"No"); // 输出:Contains 5: Yes NSLog(@"Contains 7: %@", [tree containsValue:@7] ? @"Yes" : @"No"); // 输出:Contains 7: No } return 0; } ``` 在上面的示例代码中,我们创建了一个RedBlackTree类,它使用NSMutableSet来存储红黑树的节点。insertValue方法用于插入一个值,containsValue方法用于检查某个值是否存在于红黑树中。 请注意,这只是一个简单的示例,实际上红黑树的实现要复杂得多。如果需要更复杂的红黑树功能,建议使用第三方库或自行实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值