


It turns out that the Fibonacci sequence is also written this way, did you know?
There are many answers to "Non-recursive writing of Fibonacci" on Baidu, but they are not satisfactory. Firstly, it is too difficult to understand, and secondly, the performance is similar to that of recursion.
When it comes to the Fibonacci sequence, whether you are a novice programmer or a technical veteran, the first thing that comes to mind is definitely the recursive writing method. Then, the difference between technical veterans and program novices is that they will think of saving the results of recursion to reduce repeated calculations. These are very common operations, but have you ever thought that the Fibonacci sequence can also be written in a non-recursive way?
There are many answers to "Non-recursive writing of Fibonacci" on Baidu, but they are not satisfactory. Firstly, it is too difficult to understand, and secondly, the performance is similar to that of recursion. At the beginning, I also wanted to write one myself, as long as it simulates the call stack of recursive calls, but this idea is a bit taken for granted, and the program written is also very complicated. How to do it? At this time, Depth-first traversal of the tree can come in handy.
First, we define the tree nodes:
public class Node { public Node(long value, bool visited) { Value = value; Visited = visited; } public long Value { get; set; }//存放结点的值 public bool Visited { get; set; } }
Then, we can happily learn how to write the stack of DFS
public static long Fblc(int n) { Stack<Node> s = new Stack<Node>(); s.Push(new Node(n, false)); long sum = 0; long[] childrenResultMemo = new long[n+1]; childrenResultMemo[0] = 1; childrenResultMemo[1] = 1; //long children = 0; while (s.Any()) { var cur = s.Pop(); if (cur.Visited == false) { if (childrenResultMemo[cur.Value] == 0) { cur.Visited = true; if (childrenResultMemo[cur.Value - 1] != 0 && childrenResultMemo[cur.Value - 2] != 0) { var result = childrenResultMemo[cur.Value - 1] + childrenResultMemo[cur.Value - 2]; childrenResultMemo[cur.Value] = result; sum += result; s.Push(cur); } else { s.Push(cur); s.Push(new Node(cur.Value - 1, false)); s.Push(new Node(cur.Value - 2, false)); } } else { sum += childrenResultMemo[cur.Value];//保存子树结果的优化,会有个特殊情况要处理 } } } return sum; }
The core idea of the above algorithm is to traverse the stack and pop out the stack If the top element has been visited (visited is true), skip it (the above code uses the optimization of saving subtree results, there will be a special case to be handled, which will be detailed below); otherwise, the current parent node The visited mark is true, which means it has been visited and pushed to the stack; then all its child nodes are pushed to the stack.
If you follow this idea, the code you write will not look like the one above. The amount of code will be much smaller and more concise. However, the complexity of the algorithm will be similar to that of recursive writing because there will be repeated calculations.
What should we do? There is only one solution. Exchange space for time and store the results of the subtree. If the corresponding subtree has been calculated and has results, we will no longer traverse the depth of the next layer. Use the results directly. We save the subtree results in an array:
long[] childrenResultMemo = new long[n+1];
Usually if the subtree already has results, logically it should have been visited. However, there are special cases, which are subtree 0 and subtree 1 at the beginning:
childrenResultMemo[0] = 1; childrenResultMemo[1] = 1;
Just add the results in the branch of this special case:
sum += childrenResultMemo[cur.Value];
How about this way of writing? rarely seen? In fact, the evaluation process of the Fibonacci sequence is like a depth-first traversal of the tree. So as long as it is the implementation of depth-first traversal, it is completely feasible.
Related articles:
Python prints Fibonacci sequence examples
PHP implements Fibonacci sequence
Related videos:
Data Structure Adventure—Queue Chapter
The above is the detailed content of It turns out that the Fibonacci sequence is also written this way, did you know?. For more information, please follow other related articles on the PHP Chinese website!

C#.NET is a powerful development platform that combines the advantages of the C# language and .NET framework. 1) It is widely used in enterprise applications, web development, game development and mobile application development. 2) C# code is compiled into an intermediate language and is executed by the .NET runtime environment, supporting garbage collection, type safety and LINQ queries. 3) Examples of usage include basic console output and advanced LINQ queries. 4) Common errors such as empty references and type conversion errors can be solved through debuggers and logging. 5) Performance optimization suggestions include asynchronous programming and optimization of LINQ queries. 6) Despite the competition, C#.NET maintains its important position through continuous innovation.

The future trends of C#.NET are mainly focused on three aspects: cloud computing, microservices, AI and machine learning integration, and cross-platform development. 1) Cloud computing and microservices: C#.NET optimizes cloud environment performance through the Azure platform and supports the construction of an efficient microservice architecture. 2) Integration of AI and machine learning: With the help of the ML.NET library, C# developers can embed machine learning models in their applications to promote the development of intelligent applications. 3) Cross-platform development: Through .NETCore and .NET5, C# applications can run on Windows, Linux and macOS, expanding the deployment scope.

The latest developments and best practices in C#.NET development include: 1. Asynchronous programming improves application responsiveness, and simplifies non-blocking code using async and await keywords; 2. LINQ provides powerful query functions, efficiently manipulating data through delayed execution and expression trees; 3. Performance optimization suggestions include using asynchronous programming, optimizing LINQ queries, rationally managing memory, improving code readability and maintenance, and writing unit tests.

How to build applications using .NET? Building applications using .NET can be achieved through the following steps: 1) Understand the basics of .NET, including C# language and cross-platform development support; 2) Learn core concepts such as components and working principles of the .NET ecosystem; 3) Master basic and advanced usage, from simple console applications to complex WebAPIs and database operations; 4) Be familiar with common errors and debugging techniques, such as configuration and database connection issues; 5) Application performance optimization and best practices, such as asynchronous programming and caching.

C# is widely used in enterprise-level applications, game development, mobile applications and web development. 1) In enterprise-level applications, C# is often used for ASP.NETCore to develop WebAPI. 2) In game development, C# is combined with the Unity engine to realize role control and other functions. 3) C# supports polymorphism and asynchronous programming to improve code flexibility and application performance.

C# and .NET are suitable for web, desktop and mobile development. 1) In web development, ASP.NETCore supports cross-platform development. 2) Desktop development uses WPF and WinForms, which are suitable for different needs. 3) Mobile development realizes cross-platform applications through Xamarin.

The C#.NET ecosystem provides rich frameworks and libraries to help developers build applications efficiently. 1.ASP.NETCore is used to build high-performance web applications, 2.EntityFrameworkCore is used for database operations. By understanding the use and best practices of these tools, developers can improve the quality and performance of their applications.

How to deploy a C# .NET app to Azure or AWS? The answer is to use AzureAppService and AWSElasticBeanstalk. 1. On Azure, automate deployment using AzureAppService and AzurePipelines. 2. On AWS, use Amazon ElasticBeanstalk and AWSLambda to implement deployment and serverless compute.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

Atom editor mac version download
The most popular open source editor

WebStorm Mac version
Useful JavaScript development tools
