| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 移动开发 -> LeetCode51 -- iOS使用OC写算法之递归实现N皇后 -> 正文阅读 |
|
[移动开发]LeetCode51 -- iOS使用OC写算法之递归实现N皇后 |
n?皇后问题 研究的是如何将 n?个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击。 给你一个整数 n ,返回所有不同的?n?皇后问题 的解决方案。 每一种解法包含一个不同的?n 皇后问题 的棋子放置方案,该方案中 'Q' 和 '.' 分别代表了皇后和空位。 输入:n = 4 输出:[[".Q..","...Q","Q...","..Q."],["..Q.","Q...","...Q",".Q.."]] 上代码: 定义全局变量: NSMutableArray *_result; ? ? NSMutableArray *_cols; ? ? NSMutableArray *_pie; ? ? NSMutableArray *_na; 具体实现: -(NSArray *)solveNQueens { ? ? int n = 4; ? ? if (n < 1) { ? ? ? ? return @[]; ? ? } ? ? _result = [NSMutableArray new]; ? ? /** 列 */ ? ? _cols = [NSMutableArray new]; ? ? /** 丿 */ ? ? _pie = [NSMutableArray new]; ? ? /** 捺 */ ? ? _na = [NSMutableArray new]; ? ? [self solveNQueensWidhDFS:n row:0 cur_state:[NSMutableArray new]]; ?? ? ? ? ? ? return [self _generate_result:n]; ?? ? } -(void)solveNQueensWidhDFS:(int)n row:(int)row cur_state:(NSMutableArray *)cur_state { ? ? if (row >= n) { ? ? ? ? [_result addObject:cur_state]; ? ? ? ? return; ? ? } ? ? for (int col = 0; col < n; col ++) { ? ? ? ? if ([_cols containsObject:@(col)] || [_pie containsObject:@(row + col)] || [_na containsObject:@(row - col)] ? ? ? ? ? ? ) { ? ? ? ? ? ? continue; ? ? ? ? } ? ? ? ? [_cols addObject:@(col)]; ? ? ? ? [_pie addObject:@(row + col)]; ? ? ? ? [_na addObject:@(row - col)]; ?? ? ? ? ? ? ? ? NSMutableArray *c = [NSMutableArray new]; ? ? ? ? [c addObjectsFromArray:cur_state]; ? ? ? ? [c addObject:@(col)]; ? ? ? ? [self solveNQueensWidhDFS:n row:row + 1 cur_state:c]; ?? ? ? ? ? ? ? ? [_cols removeObject:@(col)]; ? ? ? ? [_pie removeObject:@(row + col)]; ? ? ? ? [_na removeObject:@(row - col)]; ? ? } } -(NSArray *)_generate_result:(int)n { ? ? NSMutableArray *board = [NSMutableArray new]; ? ? for (NSArray *res in _result) { ? ? ? ? for (NSNumber *i in res) { ? ? ? ? ? ? NSString *point1 = [self string:i.intValue]; ? ? ? ? ? ? NSString *point2 = [self string:n - i.intValue - 1]; ? ? ? ? ? ? NSString *q = [NSString stringWithFormat:@"%@%@%@",point1,@"Q",point2]; ? ? ? ? ? ? [board addObject:q]; ? ? ? ? } ? ? } ? ? return board; } -(NSString *)string:(int)num { ? ? NSString *string = @""; ? ? for (int i = 0; i < num; i ++) { ? ? ? ? string = [string stringByAppendingString:@"."]; ? ? } ? ? return string; } leetcode链接:力扣 |
|
移动开发 最新文章 |
Vue3装载axios和element-ui |
android adb cmd |
【xcode】Xcode常用快捷键与技巧 |
Android开发中的线程池使用 |
Java 和 Android 的 Base64 |
Android 测试文字编码格式 |
微信小程序支付 |
安卓权限记录 |
知乎之自动养号 |
【Android Jetpack】DataStore |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/24 3:07:51- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |