iOS 求笛卡爾積寫法

求任意數(shù)組笛卡爾積 OC Swift 寫法

NSMutableArray *arr = [NSMutableArray array];

[arr addObject:@[@"1",@"2",@"3"]];
[arr addObject:@[@"4",@"5",@"6"]];
[arr addObject:@[@"7",@"8",@"9"]];

NSMutableArray *result = [NSMutableArray array];

[self Descartes:arr result:result layer:0 curstring:@""];  

求這三個數(shù)組的笛卡爾積 易核,結(jié)果應(yīng)該是 有27個瞻润。

具體實現(xiàn):

-(void)Descartes:(NSMutableArray <NSMutableArray <NSString *>*>*)dimvalue  result:(NSMutableArray <NSString *>*)result layer:(NSInteger)layer curstring:(NSString *)curstring{

if (layer < (dimvalue.count - 1)) {
    
    if (dimvalue[layer].count == 0) {
        [self Descartes:dimvalue result:result layer:layer + 1 curstring:curstring];
    }else{
        
        for (int i = 0; i < dimvalue[layer].count; i++) {
            
            [self Descartes:dimvalue result:result layer:layer + 1 curstring:[NSString stringWithFormat:@"%@%@",curstring,dimvalue[layer][i]]];
        }
    }
    
}else if (layer ==dimvalue.count - 1){
    
    if (dimvalue[layer].count == 0) {
        
        [result addObject:curstring];
    }else{
        
        for (int i = 0; i < dimvalue[layer].count; i++) {
            
            NSString *string = [NSString stringWithFormat:@"%@%@",curstring,dimvalue[layer][i]];
            [result addObject:string];
        }
        
    }
}

}

結(jié)果:

Paste_Image.png

Swift:

 var arr : [[String]] = [["1","2","3"],["4","5","6"],["7","8","9"]]
 var result : [String] = []

func Descartes(inout dimvalue : [[String]],inout result : [String],layer : NSInteger ,curstring : String){

if layer < dimvalue.count - 1 {
    
    if dimvalue[layer].count == 0 {
        
        Descartes(&dimvalue, result: &result, layer: layer, curstring: curstring)
    }else{
        
        for (index, _) in dimvalue[layer].enumerate() {
            
            Descartes(&dimvalue, result: &result, layer: layer + 1, curstring: curstring + dimvalue[layer][index])
        }
    }
    
}else if(layer == dimvalue.count - 1){
    
    if dimvalue[layer].count == 0 {
        
        result.append(curstring)
    }else{
        
        for (index, _) in dimvalue[layer].enumerate() {
            
            result.append(curstring + dimvalue[layer][index])
        }
        
    }
    
}

}

Descartes(&arr, result: &result, layer: 0, curstring: "")

print(result)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末惜互,一起剝皮案震驚了整個濱河市或辖,隨后出現(xiàn)的幾起案子笆檀,更是在濱河造成了極大的恐慌橄维,老刑警劉巖尺铣,帶你破解...
    沈念sama閱讀 219,427評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異挣郭,居然都是意外死亡,警方通過查閱死者的電腦和手機疗韵,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評論 3 395
  • 文/潘曉璐 我一進店門兑障,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蕉汪,你說我怎么就攤上這事流译。” “怎么了者疤?”我有些...
    開封第一講書人閱讀 165,747評論 0 356
  • 文/不壞的土叔 我叫張陵福澡,是天一觀的道長。 經(jīng)常有香客問我驹马,道長革砸,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,939評論 1 295
  • 正文 為了忘掉前任糯累,我火速辦了婚禮算利,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘泳姐。我一直安慰自己效拭,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,955評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著缎患,像睡著了一般慕的。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上挤渔,一...
    開封第一講書人閱讀 51,737評論 1 305
  • 那天肮街,我揣著相機與錄音,去河邊找鬼蚂蕴。 笑死低散,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的骡楼。 我是一名探鬼主播熔号,決...
    沈念sama閱讀 40,448評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼鸟整!你這毒婦竟也來了引镊?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,352評論 0 276
  • 序言:老撾萬榮一對情侶失蹤篮条,失蹤者是張志新(化名)和其女友劉穎弟头,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體涉茧,經(jīng)...
    沈念sama閱讀 45,834評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡赴恨,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,992評論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了伴栓。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片伦连。...
    茶點故事閱讀 40,133評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖钳垮,靈堂內(nèi)的尸體忽然破棺而出惑淳,到底是詐尸還是另有隱情,我是刑警寧澤饺窿,帶...
    沈念sama閱讀 35,815評論 5 346
  • 正文 年R本政府宣布歧焦,位于F島的核電站,受9級特大地震影響肚医,放射性物質(zhì)發(fā)生泄漏绢馍。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,477評論 3 331
  • 文/蒙蒙 一肠套、第九天 我趴在偏房一處隱蔽的房頂上張望痕貌。 院中可真熱鬧,春花似錦糠排、人聲如沸舵稠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽哺徊。三九已至室琢,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間落追,已是汗流浹背盈滴。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留轿钠,地道東北人巢钓。 一個月前我還...
    沈念sama閱讀 48,398評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像疗垛,于是被迫代替她去往敵國和親症汹。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,077評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 七律:螃蟹(新韻) 身披鎧甲盾牌精贷腕,窘態(tài)離奇面目獰背镇; 慢舉雙鰲盤水府,斜拖八爪丈河庭泽裳。 蓑翁巧遇開懷笑瞒斩,漁女先謀探...
    魯西道童閱讀 1,927評論 10 18
  • 戀愛中的女生頭腦都是昏的。 她們準備好了趕赴愛的盛宴涮总,可誰知道只有一杯冷水胸囱。 亞馬遜有一個送書的活動,我選了幾本瀑梗,...
    羞羞的麥穗閱讀 417評論 0 0
  • 文/夕四少 關(guān)于秦可卿死亡真相是紅樓一大謎嚎朽,不少專家根據(jù)脂批和曹公筆下隱約透露的信息铺纽,整合出“秦可卿淫喪天香樓”一...
    少讀紅樓閱讀 692評論 0 0
  • 我很想離開這里。沒有你的城市哟忍,我留在這里也沒有什么意義狡门。我原來一昧地拒絕,最終換來我這一生最痛苦的回憶锅很。我離開這里...
    舒蘇生閱讀 165評論 0 0