- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我只是无法理解递归。我理解所有的概念(将解决方案分解成更小的案例),并且在一遍又一遍地阅读它们之后我可以理解解决方案。但是我永远想不通如何使用递归来解决问题。有什么系统的方法可以提出递归解决方案吗?
有人可以向我解释一下他们在尝试解决以下递归问题时的思考过程吗:“使用递归返回字符串的所有排列”。
这是我解决这个问题的思考过程的一个例子。
有人可以给我一些提示来改变我的思维过程或以更好的方式思考递归,这样我就可以解决递归问题而不仅仅是查找答案。
编辑:这是我为这个问题编写另一个解决方案的思考过程。
伪代码
permutation(String s, List l) {
if(s.length() == 0) {
return list;
}
else {
String a = s.firstLetter();
l = permutation(s.substring(1, s.length) , l)
for(int i = 0; i < s.length(); i++) {
// loop that iterates through list of permutations
// that have been "solved"
for(int j=0; j < l.size(); j++) {
// loop that iterates through all positions of every
// permutation and inserts the first letter
String permutation Stringbuilder(l[i]).insert(a, j);
// insert the first letter at every position in the
// single permutation l[i]
l.add(permutation);
}
}
}
}
最佳答案
我认为,要理解一个复杂的概念,您应该从一个笑话(但正确)的解释开始。
因此,采用递归沙拉的定义:
Recursive Salad is made of apples, cucumbers and Recursive Salad.
至于分析,它类似于数学归纳法。
最后一步
的代码。 “将解决方案分解成更小的案例”是远远不够的。主要规则是:每个数学任务比 2x2 更复杂,应该从头开始解决。不仅是递归的。如果您遵循该规则,数学将成为您的玩具。如果您不这样做,那么您在以非偶然方式解决任何任务时总会遇到严重问题。
你的任务设置方式不好。你必须解决任务,而不是通过任何具体的事情来解决任务。从目标开始,而不是从给定的工具或数据开始。并一步一步地移动到数据,有时使用一些方便的方法。递归解决方案应该自然而然地自动出现。或者它不应该,你会用其他方式来做。
阅读 G.Polya 的《How to Solve It》一书。如果你的数学/IT 老师没有建议,他应该被解雇。问题是,他们中的 99% 应该被解雇……:-(。不要认为,互联网上的引用就足够了。读这本书。这是数学之王
.
(代码不是真正的 Java)(代码不是为了有效)
我们需要:一个包含所有不同字符的字符串的排列列表。
可以写成List
因此,该函数准备就绪时,将获取要排列的字符串并返回该列表
List<String> allPermutations(String source){}
要返回该列表,函数必须将这样的列表作为局部变量。
List<String> allPermutations(String source){
List<String> permutResult=new List<String>();
return permutResult;
}
假设我们已经找到几乎整个字符串的排列,但其中的最后一个字符。
List<String> allPermutations(String source){
List<String> permutResult=new List<String>();
...we have found permutations to all chars but the last
We have to take that last char and put it into every possible place in every already found permutation.
return permutResult;
}
但是我们已经找到了排列,我们可以将其编写为我们的函数,用于更短的字符串!
List<String> allPermutations(String source){
List<String> permutResult=new List<String>();
permutFound=allPermutations(substr(source,source.length-1));
for (String permutation: permutFound){
for (int i=0;i<=permutation.length;i++){
String newPermutation=permutation.insert(source[last],i);
permutResult.add(newPermutation);
}
}
return permutResult;
}
很高兴,我们不需要计算和使用源字符串的当前长度——我们一直在处理最后一个字符……但是开始呢?我们不能在空源中使用我们的函数。但是我们可以改变它,这样我们就可以使用它了!一开始我们需要一个空字符串的排列。我们也归还它。
List<String> allPermutations(String source){
List<String> permutResult=new List<String>();
if (source.length==0){
permutResult.add("");
}
permutFound=allPermutations(substr(source,source.length-1));
for (String permutation: permutFound){
for (int i=0;i<=permutation.length;i++){
String newPermutation=permutation.insert(source[last],i);
permutResult.add(newPermutation);
}
}
return permutResult;
}
所以,最后我们让程序也能在启动时运行。就这样。
关于algorithm - 递归思维的算法是什么? (在具体例子上),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22161818/
我是 Robert,我在使用 JavaScript 时遇到了一些问题。 我得到了一个 (这是隐藏的)。我唯一想问你的是:我想检查日期是否在 中已通过。如果通过了我想改变CSS中容器的背景颜色。不幸的
所以我的问题是我想要求输入使用扫描仪的信息,但它根本不打印出来。当它显示跳过的扫描仪的值时,Scanner CheeseType = new Scanner(System.in);,我得到 null。
Fe_Order_Items fe_order_items_id fe_order_specification_id fe_users_id fe_menu_items_id fe_order_ite
人们普遍提到 - “Celery 是一个基于分布式消息传递的异步任务队列/作业队列”。虽然我知道如何使用 Celery 工作人员等。但内心深处我不明白分布式消息传递的真正重要性和意义以及任务队列在其中
我试图理解下面的代码,但有一些我以前从未见过的东西,那就是:“\&\&” 这是代码: int main() { fork() \&\& (fork() || fork()); exit(EXIT_SU
您好,我是论坛新手。 我有很多使用 python 的经验,但没有使用 tkinter 的经验。 这是我的代码: from tkinter import * def Done(): celEn
在 C# 中,假设我们有一个通用类和一个具体类 [Serializable] public class GenericUser { ... [Serializable] public class Co
我尝试使用的库有一个通用抽象类,其中有两个实现该基础的子类。我想编写一个类,它将根据构造函数参数的参数类型自动创建其中一个子级的实例。 基类没有默认构造函数 基类的构造函数也需要其他通用类的实例 代码
我是 Angular 的新手,我一直在尝试了解它的工作原理。我正在制作一个简单的应用程序,其中有人可以通过简单的 html 界面添加用户并使用 SQLite 将其存储在数据库中,然后他们可以编辑或删除
我想创建一个用于存储数据的对象,限制读/写访问。 例如: OBJ obj1; OBJ obj2; // DataOBJ has 2 methods : read() and write() DataO
注入(inject)/隔离密封在 dll 中且不实现接口(interface)的类的首选方法是什么? 我们使用 Ninject。 假设我们有一个类“Server”,我们想要注入(inject)/隔离“
在花费了至少 10 个小时的时间浏览在线资源、视频和教程之后,我有两个关于将我的 Android 应用程序与 mySQL 数据库连接的问题。 保存文件 1) 所有教程都将 php 文件保存在 C/WA
许多有经验的开发人员建议不要使用 Django multi-table inheritance因为它的性能不佳: Django gotcha: concrete inheritance通过 Jacob
我知道我冒着挨揍的风险,但我觉得我在这件事上要绕圈子。为了让模型可用于多个项目,我们已将模型移出到一个单独的项目(一个 DLL)中,作为一系列要实现的接口(interface)。我们的界面上有这一行:
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我遇到了一个特定 mac 的问题,它没有显示我正确构建的某个网站。我测试过的所有其他 mac 和 pc 都能正确显示网站,但是在所有浏览器中这个特定的 mac 显示不正确就像提到的那样,这在其他每台计
给定这段代码 public override void Serialize(BaseContentObject obj) { string file = ObjectDataStoreFold
我已经搜索了网络和我的服务器,但我无法找到我网站的 php.ini。我的网站出现以下错误。 Class 'finfo' not found Details G:\inetpub\wwwroot\lan
SQL 爱好者: 我正在尝试通过玩以下用例来挖掘我一些生疏的 sql 技能: 假设我们有一家有线电视公司,并且有跟踪的数据库表: 电视节目, 观看我们节目的客户,以及 观看事件(特定客户观看特定节目的
我正在设计一个使用 HTML5 网络组件(HTML 导入、影子 DOM、模板和自定义 HTML 元素)的网络应用程序,这些组件是通过普通 JavaScript(无框架)实现的。 Web 应用程序相当简
我是一名优秀的程序员,十分优秀!