//
// 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-遍历和排序的更多相关文章

  1. c# Dictionary的遍历和排序

    c# Dictionary的遍历和排序 c#遍历的两种方式 for和foreach for: 需要指定首位数据.末尾数据.数据长度: for遍历语句中可以改变数据的值: 遍历规则可以自定义,灵活性较高 ...

  2. Object-c学习之路八(NSArray(数组)遍历和排序)

    今天学习了NSArray的遍历和排序,现在在这里做一下总结: 遍历现在实现了四中方法: 排序大概有三中方法:(代码中都有注释) 关于对象的排序还是以Student和Book为例 每个Student持有 ...

  3. jdk8中关于操作集合的一些新特性,遍历和排序操作

    jdk8增加了不少新的东西,在集合操作这块,就有如 lamda表达式,stream,sort,optional等新的类,主要涉及遍历和排序等方面,新特性提升了不少性能,我们开发就是要拥抱新事物,守着老 ...

  4. PCB 合拼遍历(全排序+旋转90度) 基本遍历方法

    分享一下PCB合拼的组合的遍历方法,在分享之前先纠正一下 PCB拼板之多款矩形排样算法实现--学习  时间复杂度计算错误  一.PCB 合拼(全排序+旋转90度)的时间复杂度是多少? 二.合拼遍历(全 ...

  5. java 集合之Arraylist的遍历及排序

    最近培训是先学习java基础 从最基本的开始学起 因为今天刚刚开博客 要把上周的一些重点内容归纳一下 1.Arraylist常用遍历以及排序 import java.util.ArrayList; i ...

  6. c# Dictionary的遍历和排序(转)

    c#遍历的两种方式 for和foreach for: 需要指定首位数据.末尾数据.数据长度: for遍历语句中可以改变数据的值: 遍历规则可以自定义,灵活性较高 foreach: 需要实现ienume ...

  7. [java学习笔记]java语言基础概述之数组的定义&常见操作(遍历、排序、查找)&二维数组

    1.数组基础 1.什么是数组:           同一类型数据的集合,就是一个容器. 2.数组的好处:           可以自动为数组中的元素从零开始编号,方便操作这些数据. 3.格式:  (一 ...

  8. [转载]C# HashTable 遍历与排序

    private void Form1_Load(object sender, EventArgs e) { Hashtable ht = new Hashtable(); ht.Add("j ...

  9. C#中hashtable的赋值、取值、遍历、排序操作

    一,哈希表(Hashtable)简述 在.NET Framework中,Hashtable是System.Collections命名空间提供的一个容器,用于处理和表现类似key/value的键值对,其 ...

  10. HashMap的遍历和排序

    1.HashMap的遍历 package com.sheepmu; import java.util.HashMap; import java.util.Iterator; import java.u ...

随机推荐

  1. Can't initialize metastore for hive

    there maybe many reason to cause this,today our issue is that, if you execute hive –database dbname ...

  2. LESSON THREE

    安装redis,并使用ruby进行简单测试.             使用redis客户端ruby测试 安装gem yum install rubygems  安装ruby所需的redis-rb程序库 ...

  3. Ajax与用户交互的存储格式JSON

    数据存储是JavaScript的核心功能,这是一个在学习前期的一个容易让人迷惑的问题.它并不是那种像页面滑动.幻灯片展示.淡入淡出等吸引人眼球的特效.适当的存放好数据,就有利于我们组织起结构,又能使应 ...

  4. 二分图最大匹配算法-Hopcroft-Karp模板

    时间复杂度:O((√V)*E) #include<stdio.h> #include<string.h> ,M=,INF=0x3f3f3f3f; int dx[N],dy[M] ...

  5. AC日记——津津的储蓄计划 P1089 (水!)

    题目描述 津津的零花钱一直都是自己管理.每个月的月初妈妈给津津300元钱,津津会预算这个月的花销,并且总能做到实际花销和预算的相同. 为了让津津学习如何储蓄,妈妈提出,津津可以随时把整百的钱存在她那里 ...

  6. LYK 快跑!(LYK别打我-)(话说LYK是谁)

    LYK 快跑!(run) Time Limit:5000ms Memory Limit:64MB 题目描述 LYK 陷进了一个迷宫! 这个迷宫是网格图形状的. LYK 一开始在(1,1)位置, 出口在 ...

  7. ExtJS要利用观察者模式 去实现自定义的事件

    // 要利用观察者模式 去实现自定义的事件 //1:由于浏览器他自己能定义内置的事件(click/blur...) // 我们也应该有一个类似于浏览器这样的类,这个类 自己去内部定义一些事件(自定义事 ...

  8. 开坑,Unix环境高级编程,转行之路又得缓缓了

    不要问我基础,我用了近6年的Linux系统,最早的版本可以追溯到Ubuntu 8.04,常用的命令 VIM基本上是没压力,遇到问题google 配置环境变量 网络环境也不在话下, C语法基本熟练,过去 ...

  9. 使用EXISTS语句注意点

    1.使用EXISTS语句,其目标列一般用“*”,因为带EXISTS的子查询只返回真值或假值,给出列名无实际意义. 2.使用EXISTS语句一定要注意上下两个表之间要建立联系. 例如,查询所有选修了1号 ...

  10. center

    center标签对其包围的文本进行水平居中处理