c ++遞歸算法數的計數_C ++程序使用數組中的遞歸查找數字的最后一次出現

c ++遞歸算法數的計數

Given an array of length N and an integer x, you need to find and return the last index of integer x present in the array. Return -1 if it is not present in the array. Last index means - if x is present multiple times in the array, return the index at which x comes last in the array.

給定長度為N和整數x的數組,您需要查找并返回數組中存在的整數x的最后一個索引。 如果數組中不存在,則返回-1。 Last index表示-如果x在數組中多次出現,則返回x在數組中最后出現的索引。

You should start traversing your array from 0, not from (N - 1). Do this recursively. Indexing in the array starts from 0.

您應該從0開始遍歷數組,而不是從(N-1)開始遍歷數組。 遞歸執行此操作。 數組中的索引從0開始。

Input Format:

輸入格式:

  • Line 1 : An Integer N i.e. size of array

    第1行:整數N,即數組的大小

  • Line 2 : N integers which are elements of the array, separated by spaces

    第2行: N個整數,它們是數組的元素,以空格分隔

  • Line 3 : Integer x

    第3行:整數x

Output Format: last index or -1

輸出格式:最后一個索引或-1

Constraints: 1 <= N <= 10^3

限制條件: 1 <= N <= 10 ^ 3

Example

    Input:
4
9 8 10 8
8
Output:
3

Description:

描述:

Here, we have to find the last occurrence of x. Therefore, in this example the last occurrence of 8 happens in index 3, and hence the output is 3.

在這里,我們必須找到x的最后一次出現。 因此,在此示例中,最后一次出現8發生在索引3中,因此輸出為3。

Algorithm:

算法:

Step 1: To solve this using recursion, make a recursion function with inputs, and a variable currIndex to traverse the input array.

步驟1:要使用遞歸解決此問題,請使用輸入創建遞歸函數,并使用變量currIndex遍歷輸入數組。

Step2: Base Case:- If currIndex == size of the input array, return -1, i.e element not found.

步驟2:基本情況:-如果currIndex ==輸入數組的大小,則返回-1,即找不到元素。

Step3: Take input of next recursion call ,withcurrIndex incremented by 1 , in a variable ‘index’.

步驟3:在變量“ index”中,獲取下一個遞歸調用的輸入,其currIndex遞增1。

Step 4:
If(index == -1 && input[currIndex] == x)
Return currIndex
Else
Return index;

第4步:
If(索引== -1 &&輸入[currIndex] == x)
返回currIndex
其他
返回索引;

C ++源代碼/功能: (C++ Source Code/Function:)

#include<bits/stdc++.h>
using namespace std;
int lastIndex(int input[], int size, int x, int currIndex){
if(currIndex== size){
return -1;
}
int index = lastIndex(input,size,x,currIndex+1);
if(index == -1 && input[currIndex] == x){
return currIndex;
}
else{
return index;
}
}
int main(){
int input[] = {9,8,10,8};
int x = 8;
int size = 4;
cout<<lastIndex(input,size,x,0);
return 0;
}

Output

輸出量

3

翻譯自: https://www.includehelp.com/cpp-programs/find-last-occurrence-of-a-number-using-recursion-in-an-array.aspx

c ++遞歸算法數的計數

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

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

相關文章

關于遞歸的理解

之前看了許多關于遞歸的理解&#xff0c;還是是懂非懂的&#xff0c;這個問題一直糾結在心里。 今天又碰到這個遞歸問題了&#xff0c;我認為一定要把問題分析清楚了&#xff0c;以后再遇到這樣的問題或者類似問題才能輕車熟路&#xff0c;不然又要頭疼或者成為問題的瓶頸了。 …

CPU使用率的查看以及性能分析(perf top/record/report)

目錄CPU使用率查看CPU使用率&#xff08;top、pidstat解釋&#xff09;CPU使用率過高perf topperf record 和 perf reportCPU使用率 Linux通過/proc虛擬文件系統&#xff0c;向用戶空間提供了系統內部狀態的信息。 /proc/stat提供的就是系統的CPU和任務統計信息。 執行命令cat…

OpenSSL再曝CCS注入漏洞-心傷未愈又成篩子

太戲劇了&#xff0c;昨晚看了佳片有約&#xff0c;還不錯&#xff0c;2012版的《完美回顧》&#xff0c;像我這樣的人依舊選擇用電視或者去影院看電影&#xff0c;在沒有中間插播廣告的時候&#xff0c;體驗憋尿得過程中&#xff0c;總是能突然有非常多的想法&#xff0c;這是…

如何從JavaScript數組中獲取多個隨機唯一元素?

The JavaScript is a very versatile language and it has a function almost everything that you want. JavaScript是一種非常通用的語言&#xff0c;它幾乎具有您想要的所有功能。 Here, we will show you how to generate random unique elements from an array in JavaSc…

用SQL語句添加刪除修改字段

1.增加字段 alter table docdsp add dspcodechar(200)2.刪除字段 ALTER TABLE table_NAME DROP COLUMNcolumn_NAME3.修改字段類型 ALTER TABLE table_name ALTER COLUMNcolumn_name new_data_type4.sp_rename 改名 EXEC sp_rename [dbo].[Table_1].[fi…

通過命令修改wampserver的mysql密碼

WAMP安裝好后&#xff0c;mysql教程密碼是為空的&#xff0c;那么要如何修改呢&#xff1f;其實很簡單&#xff0c;通過幾條指令就行了&#xff0c;下面我就一步步來操作。 首先&#xff0c;通過WAMP打開mysql控制臺。 提示輸入密碼&#xff0c;因為現在是空&#xff0c;所以直…

DBNull

1、執行ExecuteScalar時&#xff0c;要進行Null判斷&#xff0c;因為對Null進行操作會報&#xff1a;NullReferenceException 2、返回DBNull的情況&#xff0c;因為DBNull是用來表示數據庫中Null的&#xff0c;所以如果數據中返回null&#xff0c;程序中就是DBNull&#xff0c…

什么是ACID理論(二階段、三階段提交、TCC)

目錄二階段提交協議TCC&#xff08;Try-Confirm-Cancel&#xff09;預留成功預留失敗三階段提交協議總結Some questionsreferenceACID理論時對事務特性的抽象和總結&#xff0c;想要實現ACID需要掌握二階段提交協議以及TCC 這里是有關協議的論文PDF鏈接&#xff1a; CONCURRENC…

oracle安裝后新建數據庫實例及配置

ORA-12514 TNS 監聽程序當前無法識別連接描述符中請求服務 的解決方法 (2011-01-20 13:50:37) 轉載▼標簽&#xff1a; it 分類&#xff1a; 技術早上同事用PL/SQL連接虛擬機中的Oracle數據庫&#xff0c;發現又報了“ORA-12514 TNS 監聽程序當前無法識別連接描述符中請求服務…

html5游戲開發--動靜結合(二)-用地圖塊拼成大地圖 初探lufylegend

一、前言 本次教程將向大家講解如何用html5將小地圖塊拼成大地圖&#xff0c;以及如何用現有的高級html5游戲開發庫件lufylegend.js開發游戲。 首先讓我們來了解了解如何用html5實現動畫&#xff0c;畢竟“動靜結合”是先有動再有靜。看了上一章的內容&#xff0c;或許你就有了…

BASE理論(基本可用策略+ 最終一致性實現)

目錄實現基本可用的幾個策略1、流量削峰&#xff08;不同地區售票時間錯峰出售&#xff09;2、延遲響應&#xff0c;異步處理&#xff08;買票排隊&#xff0c;基于隊列先收到用戶買票請求&#xff0c;排隊異步處理&#xff0c;延遲響應&#xff09;3、體驗降級&#xff08;看到…

一天一道算法題--6.15--卡特蘭數

感謝微信平臺---一天一道算法題---每天多一點進步- problem: 12個高矮不同的人 排成兩排 每排必須是從矮到高排列 而且第二行比對應的第一排的人高 問排列方式有多少種&#xff1f; analyse: 據說 這題 是來自于 阿里巴巴的面試題 果然 很有分量 ~~ 我反正 胡思亂想了好多 沒搞…

現有一些開源ESB總線的比較

現有的開源ESB總線中&#xff0c;自從2003年第一個開源總線Mule出現后&#xff0c;如今已經是百花爭鳴的景象了。如今我就對現有的各種開源ESB總線根據性能、可擴展性、資料文檔完整程度以及整合難易程度等方面展開。 一&#xff0e;CXF CXF的定位不是ESB總線&#xff0c;而是一…

Paxos算法(Basic Paxos 與 Multi-Paxos思想)

目錄Basic Paxos三個角色達成共識的方法對于Basic Paxos的總結Multi-Paxos領導者優化 Basic Paxos 執行referencePaxos 算法包含 2 個部分&#xff1a; 1、Basic Paxos &#xff1a; 描述多節點之間如何就某個值達成共識 2、Multi-Paxos &#xff1a; 描述執行多個Basic Paxos實…

vs2012下調試mvc4源代碼

當前流行的應該是mvc3才對。然后在研究mvc3的源代碼時候&#xff0c;Html這個屬性下的擴展方法Partial()都沒有。IntelliSense不會提示該方法&#xff0c;找了半天的資料也問了一些博友&#xff0c;沒看到好的解決棒法。最后沒轍另辟蹊蹺&#xff0c;就開始著手研究mvc4的源代碼…

JAVA UDP網絡編程學習筆記

一、UDP網絡編程概述 采用TCP協議通信時&#xff0c;客戶端的Socket必須先與服務器建立連接&#xff0c;連接建立成功后&#xff0c;服務器端也會持有客戶端連接的Socket&#xff0c;客戶端的Socket與服務器端的Socket是對應的&#xff0c;它們構成了兩個端點之間的虛擬通信鏈路…

firefox 插件開發

IDE&#xff0c;你可以嘗試下NetBeans foxbeans這個插件。轉載于:https://www.cnblogs.com/sode/archive/2013/01/25/2876562.html

13種負載均衡算法

目錄前言&#xff08;1&#xff09;輪轉調度&#xff08;Round-Robin Scheduling&#xff09;算法&#xff08;2&#xff09;加權輪轉調度&#xff08;Weighted Round-Robin Scheduling&#xff09;算法&#xff08;3&#xff09;隨機均衡調度&#xff08;Random Scheduling&am…

對于shell腳本參數獲取時的一點小技巧

問題如下&#xff1a; 根據腳本參數的個數$#進行一個循環&#xff0c;在依次輸出每個參數$1 $2 $3...... 我有一個循環變量i $i 取到這時的i為1&#xff0c;我想使用這個1再去調用$1,也是就是打印出第一個參數 就是$($i)的意思來取到第幾個參數&#xff0c;當然$($i)是不好用的…

(轉)頁游安全攻與防,SWF加密和隱藏密匙

原文鏈接&#xff1a;http://netsecurity.51cto.com/art/201211/364775.htm 頁游&#xff0c;最最核心的就是客戶端&#xff08;swf&#xff09;與服務端的游戲通信了。游戲通信產生的封包&#xff0c;內容是否可識別&#xff0c;可篡改&#xff0c;可重放&#xff0c;處理邏輯…