判斷:有那種使用了局部變量的遞歸過程在轉換成非遞歸過程時才必須使用棧

這道題的關鍵在于理解遞歸轉非遞歸與 “是否用棧” 的本質邏輯,和 “局部變量” 無關,核心看遞歸的調用上下文是否需要保存

一、遞歸的本質:依賴 “調用棧”

遞歸函數執行時,系統會用調用棧保存:

  • 每層遞歸的參數、返回地址、局部變量(不管是不是局部變量,只要遞歸嵌套,就需要保存上下文)。

比如經典的遞歸求和:

int sum(int n) {if (n == 1) return 1;// 遞歸調用,sum(n-1) 依賴上一層的 nreturn n + sum(n-1); 
}

這里?sum(3)?調用?sum(2)sum(2)?調用?sum(1),每層的?n(局部變量)會存在棧里。

二、“是否用棧” 的關鍵:是否需要模擬 “調用棧”

遞歸轉非遞歸時,不管有沒有局部變量,只要遞歸有多層嵌套(需要保存上下文),就可能需要用棧手動模擬調用棧。

反例 1(無局部變量,但需要棧):

// 遞歸打印 1~n,無局部變量(除了參數)
void print(int n) {if (n == 0) return;print(n-1);printf("%d ", n);
}

轉非遞歸時,仍需用棧保存?n?的值(模擬調用棧的嵌套),否則無法按順序打印?1 2 3

反例 2(有局部變量,但無需棧):

// 尾遞歸:遞歸調用在最后,無額外計算
int tail_sum(int n, int res) {if (n == 0) return res;// 遞歸調用后直接返回,無需保存復雜上下文return tail_sum(n-1, res + n); 
}

這種尾遞歸可直接轉迭代(用變量代替棧):

int iter_sum(int n) {int res = 0;for (int i = 1; i <= n; i++) {res += i; // 無需棧,迭代累加}return res;
}

此時,即使有局部變量(res?是函數參數,類似局部變量),也不用棧

三、題目邏輯錯誤點

題目說 “只有使用局部變量的遞歸,轉非遞歸才必須用棧”,但實際:

  • 不用局部變量的遞歸(如?print?函數),轉非遞歸可能也需要棧;
  • 用局部變量的遞歸(如尾遞歸?tail_sum?),轉非遞歸可能不需要棧。

“是否用棧” 和遞歸的嵌套結構(是否需要保存上下文)?有關,和 “是否用局部變量” 無關。因此題目說法?錯誤

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/83602.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/83602.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/83602.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

leetcode1443. 收集樹上所有蘋果的最少時間-medium

1 題目&#xff1a;收集樹上所有蘋果的最少時間 官方標定難度&#xff1a;中 給你一棵有 n 個節點的無向樹&#xff0c;節點編號為 0 到 n-1 &#xff0c;它們中有一些節點有蘋果。通過樹上的一條邊&#xff0c;需要花費 1 秒鐘。你從 節點 0 出發&#xff0c;請你返回最少需…

MySQL 索引底層原理剖析:B+ 樹結構、索引創建維護與性能優化策略全解讀

引言 在 MySQL 數據庫的世界里&#xff0c;索引是提升查詢性能的關鍵利器。然而&#xff0c;很多開發者雖然知道索引的重要性&#xff0c;但對于索引背后的底層原理卻知之甚少。本文將深入 MySQL 索引的底層實現&#xff0c;剖析 B 樹的結構特點&#xff0c;以及如何利用這些知…

【Delphi】實現在多顯示器時指定程序運行在某個顯示器上

在多顯示器時代&#xff0c;經常會出現期望將程序運行在某個指定的顯示器上&#xff0c;特別是在調試程序的時候&#xff0c;期望切換分辨率&#xff0c;單步調試時&#xff0c;此時容易導致互相卡住&#xff0c;非常不方便&#xff0c;但是通過指定程序運行在不同的顯示器上就…

不動產登記區塊鏈系統(Vue3 + Go + Gin + Hyperledger Fabric)

好久沒有介紹過新項目的制作了&#xff0c;之前做的一直都是Fisco Bcos的項目&#xff0c;沒有介紹過Hyperledger Fabric的項目&#xff0c;這次來給大家分享下。 系統概述 不動產登記與交易平臺是一個基于Hyperledger Fabric的綜合性管理系統&#xff0c;旨在實現不動產登記…

論文閱讀筆記——Large Language Models Are Zero-Shot Fuzzers

TitanFuzz 論文 深度學習庫&#xff08;TensorFlow 和 Pytorch&#xff09;中的 bug 對下游任務系統是重要的&#xff0c;保障安全性和有效性。在深度學習&#xff08;DL&#xff09;庫的模糊測試領域&#xff0c;直接生成滿足輸入語言(例如 Python )語法/語義和張量計算的DL A…

cocos3.X的oops框架oops-plugin-excel-to-json改進兼容多表單導出功能

在使用oops框架的過程中&#xff0c;它的導出數據并生成數據結構的插件oops-plugin-excel-to-json有些小的坑點&#xff0c;為滿足我個人習慣&#xff0c;對此部分進行了一個小的修改&#xff0c;有需要的拿去用&#xff0c;記錄下供大家參考&#xff1b; 一、配置&#xff1a;…

解決IDE編譯JAVA項目時出現的OOM異常問題

出現的異常如圖&#xff1a; java.lang.0utOfMemoryError:Java heap space 解決方案&#xff1a; 文件 --> 設置 搜索 編譯器&#xff08;就點擊編譯器這行&#xff09;&#xff0c;找到構建進程&#xff0c;共享堆大小&#xff0c;設置大一些&#xff0c;例如 2048 MB。 …

【Linux內核】設備模型之udev技術詳解

目錄 1. udev技術概述 2. 技術層次分析 2.1 內核層交互 2.2 規則引擎層 2.3 用戶空間實現 3. 關鍵技術要點 3.1 動態設備節點管理 3.2 熱插拔處理 3.3 模塊化規則系統 3.3.1. 變量替換功能 3.3.2. 條件判斷能力 3.3.3. 實現機制 3.3.4 應用場景 3.3.5 擴展能力 4…

群論在現代密碼學中的應用探索與實踐 —— 從理論到C語言實現

1. 引言&#xff1a;數字時代的信息安全挑戰 隨著互聯網和數字技術的快速發展&#xff0c;信息安全問題變得日益嚴峻。無論是個人隱私保護&#xff0c;還是企業數據安全&#xff0c;乃至國家安全&#xff0c;都依賴于有效的加密技術保障信息的機密性和完整性。網絡攻擊、數據泄…

前端開發處理‘流式數據’與‘非流式數據’,在接收完整與非完整性數據時應該如何渲染和使用

在前端開發中&#xff0c;處理 非流式數據 和 流式數據 的方式不同。根據是否完整接收數據、是否實時渲染的需求&#xff0c;可以分為以下四種典型場景&#xff1a; 一、四類常見場景總結 類型數據完整性是否實時渲染適用技術/方法A完整數據&#xff08;一次性返回&#xff09…

thymeleaf直接調用Spring Bean中定義的方法

thymeleaf中可以使用表達式工具對象&#xff0c;通過符號直接調Spring Bean中定義的方法 Spring Bean Component public class InvokeMethodBean {public String fun() { return "fun";} }thymeleaf中調用 <div th:text"${invokeMethodBean.fun()}"&…

虛擬斯德哥爾摩癥候群:用戶為何為缺陷AI辯護?

當韓國用戶美咲連續第七次為虛擬男友的算法錯誤辯解&#xff1a;“他只是太累了才會說傷人的話”&#xff0c;心理醫生在診斷書上寫下“數字依賴伴隨認知失調”。這種現象并非孤例——斯坦福2024年研究顯示&#xff0c;62%長期使用情感AI的用戶會主動為系統缺陷尋找合理化解釋&…

tryhackme——Abusing Windows Internals(進程注入)

文章目錄 一、Abusing Processes二、進程鏤空三、線程劫持四、DLL注入五、Memory Execution Alternatives 一、Abusing Processes 操作系統上運行的應用程序可以包含一個或多個進程&#xff0c;進程表示正在執行的程序。進程包含許多其他子組件&#xff0c;并且直接與內存或虛…

[藍橋杯]密碼脫落

密碼脫落 題目描述 X 星球的考古學家發現了一批古代留下來的密碼。 這些密碼是由 A、B、C、D 四種植物的種子串成的序列。 仔細分析發現&#xff0c;這些密碼串當初應該是前后對稱的&#xff08;也就是我們說的鏡像串&#xff09;。 由于年代久遠&#xff0c;其中許多種子…

Python繪圖庫及圖像類型

折線圖&#xff08;plot&#xff09; 繪圖庫介紹 Python中繪制折線圖的全面指南_python繪制折線圖-CSDN博客https://blog.csdn.net/2301_81064905/article/details/139689644 核心作用說明趨勢分析揭示數據隨時間推移的上升/下降趨勢、周期性波動或轉折點變化對比在單一圖表…

4種常見Python設計愛心創意實現方法

在Python中設計愛心創意有多種實現方式&#xff0c;以下介紹4種常見方法&#xff0c;并附上完整代碼&#xff1a; 方法1&#xff1a;使用數學方程繪制&#xff08;Matplotlib&#xff09; ??原理??&#xff1a;使用參數方程繪制心形曲線 ??效果??&#xff1a;光滑的數…

【Unity】R3 CSharp 響應式編程 - 使用篇(二)

一、通用的事件監聽用法 using System;using R3;using UnityEngine;namespace Aladdin.Standard.Observable.Common{public class CommonObservable : MonoBehaviour{// 默認會調用1次public SerializableReactiveProperty<int> serializableReactiveProperty;…

【原理解析】為什么顯示器Fliker dB值越大,閃爍程度越輕?

顯示器Fliker 1 顯示器閃爍現象說明2 Fliker量測方法2.1 FMA法2.2 JEITA法問題答疑&#xff1a;為什么顯示器Fliker dB值越大&#xff0c;閃爍程度越輕&#xff1f; 3 參考文獻 1 顯示器閃爍現象說明 當一個光源閃爍超過每秒10次以上就可在人眼中產生視覺殘留&#xff0c;此時…

3.需求分析與測試用例設計方法

設計方法 測試點 定義: 測試時需要考慮的可測試方面&#xff0c;不同公司可能稱為"檢查點"或其它名稱特點: 是需求分析的最后一個環節&#xff0c;用于解決"測哪里"和"怎么測"的問題舉例說明: 如同打架時的各種招數&#xff0c;如直接約架、設…

IEC 61347-1:2015 燈控制裝置安全標準詳解

IEC 61347-1:2015燈控制裝置安全標準詳解 IEC 61347-1:2015 是國際電工委員會&#xff08;IEC&#xff09;發布的燈控制裝置第1部分&#xff1a;通用要求和安全要求的核心標準&#xff0c;為各類照明用電子控制設備設定了全球通用的安全基準。該標準適用于獨立式或內置于燈具/…