iOS 面试题~两个有序数组合并成一个有序数组

//联系人:石虎  QQ: 1224614774 昵称:嗡嘛呢叭咪哄

面试题: 怎样把两个有序数组合并成有序数组呢

逻辑步骤:

1.假设两个数组为A和B

2.A和B都是从小到大的顺序进行排列

**

1.我们可以直接比较两个数组的首元素,哪个小就把这个小元素放入可变数组。

2.把小元素所在的数组中的这个元素删除。

3.继续比较两个数组中的首元素,直到有一个数组为空。那么就停止进行比较。把另外一个不空的数组元素全部放入可变数组中即可。

实现代码:

- (void)viewDidLoad {

[super viewDidLoad];

//实例化数组 A

NSMutableArray *arrA = [NSMutableArray arrayWithArray:@[@1,@3,@5,@7,@9,@11]];

//实例化数组 B

NSMutableArray *arrB = [NSMutableArray arrayWithArray:@[@8,@15,@17,@20,@22,@35]];

NSMutableArray *marr = [NSMutableArray array];

for(int i = 0; i< 100; i++)

{

if (arrA[0] < arrB[0])

{

[marr addObject:arrA[0]];

[arrA removeObject:arrA[0]];

}else

{

[marr addObject:arrB[0]];

[arrB removeObject:arrB[0]];

}

NSLog(@"已经循环了--->>%d次",i);

if (arrA.count == 0)

{

[marr addObjectsFromArray:arrB];

NSLog(@"新数组--->>%@",marr);

return;

}

if (arrB.count == 0)

{

[marr addObjectsFromArray:arrA];

NSLog(@"新数组---->> %@",marr);

return;

}

}

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1.oc基本语法 // // main.m // oc基本语法 // // Created by lanou on...
    GOT_HODOR阅读 3,349评论 0 0
  • //--------------------不可变数组1.数组的创建NSString *s1 = @"zhangs...
    small_Sun阅读 8,001评论 1 0
  • demo下载 建议一边看文章,一边看代码。 声明:关于性能的分析是基于我的测试代码来的,我也看到和网上很多测试结果...
    炸街程序猿阅读 4,198评论 0 2
  • 本文为转载: 作者:zyydeveloper 链接:http://www.jianshu.com/p/5f776a...
    Buddha_like阅读 4,472评论 0 2
  • *面试心声:其实这些题本人都没怎么背,但是在上海 两周半 面了大约10家 收到差不多3个offer,总结起来就是把...
    Dove_iOS阅读 27,400评论 30 472

友情链接更多精彩内容