1 很久没写东西了,感觉语言表达能力都不行了.好吧,忙不是理由,主要是懒.今天想把上次遇见的难题记录一下.
两个tableview的联动,后台给的数据真的不想吐槽了...所以前台处理数据..遇到的问题被我简单化 大概就是这么个命题 :已知可变数组a ,数组b, 需要根据b的顺序对a进行处理,提取b中相同类型的元素,并且除去a中多余的元素.
我感觉还是直接上代码简单易懂
-(void)paixu1 {
// NSArray *A = @[@"4",@"2",@"3",@"1"];
NSArray *arr = @[@"13",@"3",@"4",@"2",@"6",@"7",@"5",@"8",@"1",@"9",@"10",@"11"];
NSArray *array1 = @[@"4",@"6",@"1",@"3",@"2",@"2",@"5",@"4",@"7",@"5",@"8",@"4",@"10",@"9"];
NSMutableArray *array = [NSMutableArray arrayWithArray:array1];
// (44 1 3 22 5)
NSMutableArray *dateMutablearray = [@[] mutableCopy];
for (int i = 0; i < array.count; i ++) {
NSString *string = array[i];
NSMutableArray *tempArray = [@[] mutableCopy];
[tempArray addObject:string];
for (int j = i+1; j < array.count; j ++) {
NSString *jstring = array[j];
if([string isEqualToString:jstring]){
[tempArray addObject:jstring];
[array removeObjectAtIndex:j];
j -= 1;
}
}
[dateMutablearray addObject:tempArray];
}
NSLog(@"dateMutable:%@",dateMutablearray);
NSMutableDictionary *dict = [NSMutableDictionary dictionary];
[dateMutablearray enumerateObjectsUsingBlock:^(NSArray *arr, NSUInteger idx, BOOL * _Nonnull stop) {
NSString *key = arr[0];
[dict setObject:arr forKey:key];
}];
NSLog(@"Finadict %@",dict);
NSMutableArray *temp = [NSMutableArray array];
NSMutableArray *finArr = [NSMutableArray array];
for (int i = 0; i<arr.count; i++) {
NSString *str = arr[i];
@try {
temp = dict[str];
[finArr addObject:temp];
} @catch (NSException *exception) {
} @finally {
}
}
NSLog(@"---%@",finArr);
}
数组a
NSArray *arr = @[@"13",@"3",@"4",@"2",@"6",@"7",@"5",@"8",@"1",@"9",@"10",@"11"];
数组b
NSArray *array1 = @[@"4",@"6",@"1",@"3",@"2",@"2",@"5",@"4",@"7",@"5",@"8",@"4",@"10",@"9"];
排序之后最终得到的结果
实现思路 :(想明白了就很简单)
第一步
把数组b中相同的元素放在一起;
NSMutableArray *array = [NSMutableArray arrayWithArray:array1];
// (44 1 3 22 5)
NSMutableArray *dateMutablearray = [@[] mutableCopy];
for (int i = 0; i < array.count; i ++) {
NSString *string = array[i];
NSMutableArray *tempArray = [@[] mutableCopy];
[tempArray addObject:string];
for (int j = i+1; j < array.count; j ++) {
NSString *jstring = array[j];
if([string isEqualToString:jstring]){
[tempArray addObject:jstring];
[array removeObjectAtIndex:j];
j -= 1;
}
}
[dateMutablearray addObject:tempArray];
}
NSLog(@"dateMutable:%@",dateMutablearray)
此时并没有按照数组a的顺序排列的,而是按照数组b自己的循序排列.下面重点讲按照a的顺序给中间数组排序.
第二步
思路 : 遍历中间数组,把中间数组里面的小数组的第一个元素当做key值, 小数组当做vaule的值.组合成一个字典,类似于哈希表的实现方式,通过key的值取数组.
代码
NSMutableDictionary *dict = [NSMutableDictionary dictionary];
[dateMutablearray enumerateObjectsUsingBlock:^(NSArray *arr, NSUInteger idx, BOOL * _Nonnull stop) {
NSString *key = arr[0];
[dict setObject:arr forKey:key];
}];
NSLog(@"Finadict %@",dict);
然后就是根据a的顺序去排序了
第三步
有个很取巧的办法 :遍历数组a,用try catch 函数,去从字典中取数组,key的值就是数组a的元素,取到了,就把取到的数组放在finaArr的数组中,取不到抛个异常,不影响...
代码 :
NSMutableArray *temp = [NSMutableArray array];
NSMutableArray *finArr = [NSMutableArray array];
for (int i = 0; i<arr.count; i++) {
NSString *str = arr[i];
@try {
temp = dict[str];
[finArr addObject:temp];
} @catch (NSException *exception) {
} @finally {
}
}
NSLog(@"---%@",finArr);
ok ,自此 大功告成!
最后啰嗦一下,遍历数组第二步和第三步使用的方法不一样.据说通过第二步的效率最高,会开启子线程去遍历,但是这个遍历可能是无序的.如果要求有序的遍历,还是第三步中的方法最好.这个就要看大家的使用需求了..