iOS 账单数据处理

简化一下模型,一般来说服务器返回的都是按时间顺序排好的数组(unsorted),排序后如result所示。

    var result: Array<Any> = []
    /// 里面代表月份
    let unsorted = [9, 9, 9, 8, 8, 7, 6, 6, 5, 4, 4, 1]
    billSort(unsorted)
    /// 输出结果
    result = [[9, 9, 9], [8, 8], [7], [6, 6], [5], [4, 4], [1]]

关键代码:

var result: Array<Any> = []
/// 用于保存上一次排序的月份,以便接下来比较
var olderValue: Int?
func billSort(_ a: [Int]) {
    guard a.count > 1 else {
        result.append(a)
        return
    }

    olderValue = a.first
    /// 取出同月份的数据
    let currentMonth = a.filter{ $0 == olderValue }
    result.append(currentMonth)
    /// 取出不同月份的数据进行下一次比较
    let rest = a.filter{ $0 != olderValue }
    
    /// 判断是否还有未排序
    if rest.isEmpty == false {
        olderValue = rest.first
        billSort(rest)
    }
}

let unsorted = [9, 9, 9, 8, 8, 7, 6, 6, 5, 4, 4, 1]
billSort(unsorted)
print(result)
// result = [[9, 9, 9], [8, 8], [7], [6, 6], [5], [4, 4], [1]]

实际情况只需要将判定的条件换为是否同月。完整代码如下:

class BillModel {
    var timeStamp: Double?
    var money: Double?
    
    init(_ time: Double, money: Double) {
        self.timeStamp = time
        self.money = money
    }
}

func creatBill() -> [BillModel] {
    var currentTime = NSDate().timeIntervalSince1970
    var bills: [BillModel] = []
    for x in 0 ..< 10 {
        let bill = BillModel.init(currentTime, money: Double(x))
        bills.append(bill)
        currentTime -= 1000000
    }
    return bills
}

func isTheSameMonth(_ a: Double, b: Double) -> Bool {
    let aDate = Date.init(timeIntervalSince1970: a)
    let bDate = Date.init(timeIntervalSince1970: b)
    let aM = Calendar.current.dateComponents([.month], from: aDate)
    let bM = Calendar.current.dateComponents([.month], from: bDate)
    
    return aM.month == bM.month && aM.year == bM.year
}

var result: Array<Any> = []
var olderValue: BillModel?
func billSort(_ a: [BillModel]) {
    guard a.count > 1 else {
        result.append(a)
        return
    }
    
    olderValue = a.first
    let currentMonth = a.filter{ isTheSameMonth($0.timeStamp!, b: (olderValue?.timeStamp)!) }
    print(currentMonth)
    result.append(currentMonth)
    let rest = a.filter{ !isTheSameMonth($0.timeStamp!, b: (olderValue?.timeStamp)!) }
    
    if rest.isEmpty == false {
        olderValue = rest.first
        billSort(rest)
    }
}

let bills = creatBill()
billSort(bills)
print(result)

相关代码

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

推荐阅读更多精彩内容

  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 8,666评论 0 4
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 32,516评论 18 399
  • 首页 资讯 文章 资源 小组 相亲 登录 注册 首页 最新文章 IT 职场 前端 后端 移动端 数据库 运维 其他...
    Helen_Cat阅读 9,416评论 1 10
  • 一事无成的人,很多地方都是相似的。 1. 缺席 百分之八十的成功来自于出席。——伍迪·艾伦 更多的出席——这是在生...
    非常高效阅读 61,371评论 87 2,047
  • 生活对每个人公平,每个人有不同的选择,而因选择的不同又有了不同的生活。这种不同的选择,源于性格,源于经历,源于身边...
    林夕枫起阅读 2,271评论 2 8

友情链接更多精彩内容