Giter VIP home page Giter VIP logo

bdinterviewdemo's Introduction

BDInterviewDemo

NSArray *sourceArray = @[@{
                                 @"id" : @"1",
                                 @"pid" : @"0"
                                 },
                             @{
                                 @"id" : @"2",
                                 @"pid" : @"1"
                                 },
                             @{
                                 @"id" : @"3",
                                 @"pid" : @"2"
                                 },
                             @{
                                 @"id" : @"4",
                                 @"pid" : @"0"
                                 },
                             @{
                                 @"id" : @"5",
                                 @"pid" : @"4"
                                 },
                             @{
                                 @"id" : @"6",
                                 @"pid" : @"2"
                                 },
                             @{
                                 @"id" : @"7",
                                 @"pid" : @"2"
                                 },
                             @{
                                 @"id" : @"8",
                                 @"pid" : @"0"
                                 },
                             @{
                                 @"id" : @"9",
                                 @"pid" : @"5"
                                 },
                             ];
    
    NSArray *result = [self childFromRootID:@"0" sourceArray:sourceArray];
    NSLog(@"result:%@", result);
- (NSArray *)childFromRootID:(NSString *)pid sourceArray:(NSArray *)dataArray {
    NSMutableArray *array = [NSMutableArray array];
    
    for (NSDictionary *dic in dataArray) {
        if ([dic[@"pid"] isEqualToString:pid]) {
            
            NSMutableDictionary *tempDict = [NSMutableDictionary dictionary];
            tempDict[@"id"] = dic[@"id"];
            
            NSArray *tempArray = [self childFromRootID:tempDict[@"id"] sourceArray:dataArray];
            
            if (tempArray.count > 0) {
                tempDict[@"child"] = tempArray;
            }
            [array addObject:tempDict];
        }
    }
    
    return array;
}

运行结果

result:(
        {
        child =         (
                        {
                child =                 (
                                        {
                        id = 3;
                    },
                                        {
                        id = 6;
                    },
                                        {
                        id = 7;
                    }
                );
                id = 2;
            }
        );
        id = 1;
    },
        {
        child =         (
                        {
                child =                 (
                                        {
                        id = 9;
                    }
                );
                id = 5;
            }
        );
        id = 4;
    },
        {
        id = 8;
    }
)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.