iOS數組排序詳解

一、數組排序介紹

數組是在iOS開發中使用最為廣泛的數據結構之一,而數組排序也是日常開發中十分常見的需求。數組排序能夠讓我們更加方便快捷地找到數組中的最大值、最小值、中位數等。實現數組排序,需要掌握基礎排序算法,例如冒泡排序、快速排序、插入排序等。

二、排序方法

1. 冒泡排序

冒泡排序的基本思想是從數組的第一個元素開始與第二個元素進行比較,如果第一個元素大於第二個元素,則交換它們的位置,接着比較第二個元素和第三個元素,以此類推,直到排序完成。

NSArray *array = @[@5, @3, @8, @4, @1];
NSMutableArray *mArray = [NSMutableArray arrayWithArray:array];
for (int i=0; i<mArray.count-1; i++) {
    for (int j=0; j [mArray[j+1] integerValue]) {
            [mArray exchangeObjectAtIndex:j withObjectAtIndex:j+1];
        }
    }
}

2. 快速排序

快速排序是一種高效的排序算法,其基本思想是選擇一個基準元素,將數組按照基準元素分成兩部分,一部分比基準元素小,一部分比基準元素大。然後分別對這兩部分進行遞歸操作。

- (NSMutableArray *)quickSortWithArray:(NSMutableArray *)array {
    if (array.count <= 1) {
        return array;
    }
    NSMutableArray *leftArray = [NSMutableArray array];
    NSMutableArray *rightArray = [NSMutableArray array];
    NSInteger index = array.count/2;
    NSNumber *baseNum = [array objectAtIndex:index];
    [array removeObject:baseNum];
    for (NSNumber *num in array) {
        if ([num integerValue] < [baseNum integerValue]) {
            [leftArray addObject:num];
        } else {
            [rightArray addObject:num];
        }
    }
    NSMutableArray *resultArray = [NSMutableArray array];
    [resultArray addObjectsFromArray:[self quickSortWithArray:leftArray]];
    [resultArray addObject:baseNum];
    [resultArray addObjectsFromArray:[self quickSortWithArray:rightArray]];
    
    return resultArray;
}

3. 插入排序

插入排序的基本思想是將數組分成有序區和無序區,從無序區中取出元素插入到有序區中,插入時要保證有序區的元素仍舊有序。

NSArray *array = @[@5, @3, @8, @4, @1];
NSMutableArray *mArray = [NSMutableArray arrayWithArray:array];
for (int i=1; i0; j--) {
        if ([mArray[j] integerValue] < [mArray[j-1] integerValue]) {
            [mArray exchangeObjectAtIndex:j withObjectAtIndex:j-1];
        }
    }
}

三、總結

數組排序是iOS開發中的基本操作,它能夠讓我們更輕鬆地處理數據。常用的排序方法有冒泡排序、快速排序和插入排序,每種排序方法的適用場景不同,具體使用需要根據實際情況來選擇。掌握這些排序方法,能夠使我們的代碼更加規範、高效。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/256810.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-15 12:42
下一篇 2024-12-15 12:42

相關推薦

  • Python導入數組

    本文將為您詳細闡述Python導入數組的方法、優勢、適用場景等方面,並附上代碼示例。 一、numpy庫的使用 numpy是Python中一個強大的數學庫,其中提供了非常豐富的數學函…

    編程 2025-04-29
  • Python返回數組:一次性搞定多種數據類型

    Python是一種多用途的高級編程語言,具有高效性和易讀性的特點,因此被廣泛應用於數據科學、機器學習、Web開發、遊戲開發等各個領域。其中,Python返回數組也是一項非常強大的功…

    編程 2025-04-29
  • Python去掉數組的中括號

    在Python中,被中括號包裹的數據結構是列表,列表是Python中非常常見的數據類型之一。但是,有些時候我們需要將列表展開成一維的數組,並且去掉中括號。本文將為大家詳細介紹如何用…

    編程 2025-04-29
  • Python操作數組

    本文將從多個方面詳細介紹如何使用Python操作5個數組成的列表。 一、數組的定義 數組是一種用於存儲相同類型數據的數據結構。Python中的數組是通過列表來實現的,列表中可以存放…

    編程 2025-04-29
  • Python二維數組對齊輸出

    本文將從多個方面詳細闡述Python二維數組對齊輸出的方法與技巧。 一、格式化輸出 Python中提供了格式化輸出的方法,可以對輸出的字符串進行格式化處理。 names = [‘A…

    編程 2025-04-29
  • Java創建一個有10萬個元素的數組

    本文將從以下方面對Java創建一個有10萬個元素的數組進行詳細闡述: 一、基本介紹 Java是一種面向對象的編程語言,其強大的數組功能可以支持創建大規模的多維數組以及各種複雜的數據…

    編程 2025-04-28
  • Python數組隨機分組用法介紹

    Python數組隨機分組是一個在數據分析與處理中常用的技術,它可以將一個大的數據集分成若干組,以便於進行處理和分析。本文將從多個方面對Python數組隨機分組進行詳細的闡述,包括使…

    編程 2025-04-28
  • Python數組索引位置用法介紹

    Python是一門多用途的編程語言,它有着非常強大的數據處理能力。數組是其中一個非常重要的數據類型之一。Python支持多種方式來操作數組的索引位置,我們可以從以下幾個方面對Pyt…

    編程 2025-04-28
  • Python語言數組從大到小排序符號的用法介紹

    當我們使用Python進行編程的時候,經常需要對數組進行排序從而使數組更加有序,而數組的排序方式有很多,其中從大到小排序符號是一種常見的排序方式。本文將從多個方面對Python語言…

    編程 2025-04-28
  • Python列錶轉numpy數組

    本文將闡述Python中列表如何轉換成numpy數組。在科學計算和數據分析領域中,numpy數組扮演着重要的角色。Python與numpy的無縫結合使得數據操作更加方便和高效。因此…

    編程 2025-04-27

發表回復

登錄後才能評論