ios-遍历和排序
//
// main.m
// OC-遍历和排序-homework
//
// Created by dllo on 16/2/25.
// Copyright © 2016年 dllo. All rights reserved.
// #import <Foundation/Foundation.h>
#import "Person.h"
int main(int argc, const char * argv[]) {
@autoreleasepool {
// 要求 :
// 1、创建1个包含5个字符串元素的数组; 2、 for循环倒序输出所有元素; 3、 for...in完成所有字符串元素的拼接( 成 个
// 新的字符串),并输出拼接好的字符串。
NSArray *strArray = @[@"nanjing", @"shanghai", @"beijing", @"shangxi", @"chongqing"];
for (int i = 0; i < strArray.count; i++) {
NSLog(@"%@", [strArray objectAtIndex:strArray.count - 1 - i]);
}
NSMutableString *str = [NSMutableString stringWithCapacity:20];
for (NSString *string in strArray) {
[str appendString:string];
}
NSLog(@"%@", str); // 要求:
// 1、创建1个包含5个person对象的数组(姓名 英 ); 2、 for循环找到年龄最 的Person对象; 3、 for...in遍历数组,把 于某个年龄的Person对象的姓名后 拼接上字符串“-brother”。 Person *per1 = [[Person alloc]initWithName:@"ma" sex:@"male" age:26];
Person *per2 = [[Person alloc]initWithName:@"liutaifeng" sex:@"male" age:22];
Person *per3 = [[Person alloc]initWithName:@"zhengfeng " sex:@"male" age:23];
Person *per4 = [[Person alloc]initWithName:@"ma" sex:@"male" age:27];
Person *per5 = [[Person alloc]initWithName:@"ma" sex:@"male" age:29];
NSArray *array = [NSArray arrayWithObjects:per1, per2, per3, per4, per5, nil];
Person *per = [[Person alloc]initWithName:@"majian" sex:@"male" age:29];
for (int i = 0; i < array.count; i++) {
if ([[array objectAtIndex:i] age] < [per age]) {
per = [array objectAtIndex:i];
}
}
NSLog(@"%@", [per name]); NSArray *newArray = [array sortedArrayUsingSelector:@selector(compareWithName:)];
NSLog(@"%@", newArray); NSArray *newArray2 = [array sortedArrayUsingSelector:@selector(compareWithSex:)];
NSLog(@"%@", newArray2); NSArray *newArray3 = [array sortedArrayUsingSelector:@selector(compareWithAge:)];
NSLog(@"%@", newArray3); NSSortDescriptor *sortOfName = [[NSSortDescriptor alloc]initWithKey:@"name" ascending:YES]; NSSortDescriptor *sortOfAge = [[NSSortDescriptor alloc]initWithKey:@"age" ascending:YES]; NSArray *array1 = [array sortedArrayUsingDescriptors:@[sortOfName, sortOfAge]];
NSLog(@"%@", array1); }
return 0;
}
Person.m文件:
//
// Person.m
// OC-遍历和排序-homework
//
// Created by dllo on 16/2/25.
// Copyright © 2016年 dllo. All rights reserved.
// #import "Person.h" @implementation Person - (instancetype)initWithName:(NSString *)name sex:(NSString *)sex age:(NSInteger)age{
self = [super init];
if (self) {
_name= name;
_age = age;
_sex = sex;
}
return self; }
- (NSComparisonResult)compareWithName:(Person *)anOtherPerson{ return [self.name compare:anOtherPerson.name]; } - (NSComparisonResult)compareWithAge:(Person *)anOtherPerson{
if (self.age > anOtherPerson.age) {
return NSOrderedDescending;
}else if(self.age < anOtherPerson.age){
return NSOrderedAscending; }else{
return NSOrderedSame;
} }
- (NSComparisonResult)compareWithSex:(Person *)anOtherPerson{
return [self.sex compare:anOtherPerson.sex];
}
- (NSString *)description
{
return [NSString stringWithFormat:@"name:%@, sex:%@, age:%ld", _name, _sex, _age];
}
@end
ios-遍历和排序的更多相关文章
- c# Dictionary的遍历和排序
c# Dictionary的遍历和排序 c#遍历的两种方式 for和foreach for: 需要指定首位数据.末尾数据.数据长度: for遍历语句中可以改变数据的值: 遍历规则可以自定义,灵活性较高 ...
- Object-c学习之路八(NSArray(数组)遍历和排序)
今天学习了NSArray的遍历和排序,现在在这里做一下总结: 遍历现在实现了四中方法: 排序大概有三中方法:(代码中都有注释) 关于对象的排序还是以Student和Book为例 每个Student持有 ...
- jdk8中关于操作集合的一些新特性,遍历和排序操作
jdk8增加了不少新的东西,在集合操作这块,就有如 lamda表达式,stream,sort,optional等新的类,主要涉及遍历和排序等方面,新特性提升了不少性能,我们开发就是要拥抱新事物,守着老 ...
- PCB 合拼遍历(全排序+旋转90度) 基本遍历方法
分享一下PCB合拼的组合的遍历方法,在分享之前先纠正一下 PCB拼板之多款矩形排样算法实现--学习 时间复杂度计算错误 一.PCB 合拼(全排序+旋转90度)的时间复杂度是多少? 二.合拼遍历(全 ...
- java 集合之Arraylist的遍历及排序
最近培训是先学习java基础 从最基本的开始学起 因为今天刚刚开博客 要把上周的一些重点内容归纳一下 1.Arraylist常用遍历以及排序 import java.util.ArrayList; i ...
- c# Dictionary的遍历和排序(转)
c#遍历的两种方式 for和foreach for: 需要指定首位数据.末尾数据.数据长度: for遍历语句中可以改变数据的值: 遍历规则可以自定义,灵活性较高 foreach: 需要实现ienume ...
- [java学习笔记]java语言基础概述之数组的定义&常见操作(遍历、排序、查找)&二维数组
1.数组基础 1.什么是数组: 同一类型数据的集合,就是一个容器. 2.数组的好处: 可以自动为数组中的元素从零开始编号,方便操作这些数据. 3.格式: (一 ...
- [转载]C# HashTable 遍历与排序
private void Form1_Load(object sender, EventArgs e) { Hashtable ht = new Hashtable(); ht.Add("j ...
- C#中hashtable的赋值、取值、遍历、排序操作
一,哈希表(Hashtable)简述 在.NET Framework中,Hashtable是System.Collections命名空间提供的一个容器,用于处理和表现类似key/value的键值对,其 ...
- HashMap的遍历和排序
1.HashMap的遍历 package com.sheepmu; import java.util.HashMap; import java.util.Iterator; import java.u ...
随机推荐
- Can't initialize metastore for hive
there maybe many reason to cause this,today our issue is that, if you execute hive –database dbname ...
- LESSON THREE
安装redis,并使用ruby进行简单测试. 使用redis客户端ruby测试 安装gem yum install rubygems 安装ruby所需的redis-rb程序库 ...
- Ajax与用户交互的存储格式JSON
数据存储是JavaScript的核心功能,这是一个在学习前期的一个容易让人迷惑的问题.它并不是那种像页面滑动.幻灯片展示.淡入淡出等吸引人眼球的特效.适当的存放好数据,就有利于我们组织起结构,又能使应 ...
- 二分图最大匹配算法-Hopcroft-Karp模板
时间复杂度:O((√V)*E) #include<stdio.h> #include<string.h> ,M=,INF=0x3f3f3f3f; int dx[N],dy[M] ...
- AC日记——津津的储蓄计划 P1089 (水!)
题目描述 津津的零花钱一直都是自己管理.每个月的月初妈妈给津津300元钱,津津会预算这个月的花销,并且总能做到实际花销和预算的相同. 为了让津津学习如何储蓄,妈妈提出,津津可以随时把整百的钱存在她那里 ...
- LYK 快跑!(LYK别打我-)(话说LYK是谁)
LYK 快跑!(run) Time Limit:5000ms Memory Limit:64MB 题目描述 LYK 陷进了一个迷宫! 这个迷宫是网格图形状的. LYK 一开始在(1,1)位置, 出口在 ...
- ExtJS要利用观察者模式 去实现自定义的事件
// 要利用观察者模式 去实现自定义的事件 //1:由于浏览器他自己能定义内置的事件(click/blur...) // 我们也应该有一个类似于浏览器这样的类,这个类 自己去内部定义一些事件(自定义事 ...
- 开坑,Unix环境高级编程,转行之路又得缓缓了
不要问我基础,我用了近6年的Linux系统,最早的版本可以追溯到Ubuntu 8.04,常用的命令 VIM基本上是没压力,遇到问题google 配置环境变量 网络环境也不在话下, C语法基本熟练,过去 ...
- 使用EXISTS语句注意点
1.使用EXISTS语句,其目标列一般用“*”,因为带EXISTS的子查询只返回真值或假值,给出列名无实际意义. 2.使用EXISTS语句一定要注意上下两个表之间要建立联系. 例如,查询所有选修了1号 ...
- center
center标签对其包围的文本进行水平居中处理