這篇文章主要講解了“C#移動(dòng)零和爬樓梯的實(shí)現(xiàn)方法是什么”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“C#移動(dòng)零和爬樓梯的實(shí)現(xiàn)方法是什么”吧!
我們提供的服務(wù)有:成都網(wǎng)站制作、做網(wǎng)站、微信公眾號(hào)開(kāi)發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、上黨ssl等。為成百上千家企事業(yè)單位解決了網(wǎng)站和推廣的問(wèn)題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的上黨網(wǎng)站制作公司
給定一個(gè)數(shù)組 nums,編寫一個(gè)函數(shù)將所有 0 移動(dòng)到數(shù)組的末尾,同時(shí)保持非零元素的相對(duì)順序。
輸入: [0,1,0,3,12]
輸出: [1,3,12,0,0]
必須在原數(shù)組上操作,不能拷貝額外的數(shù)組。
盡量減少操作次數(shù)。
public void MoveZeroes(int[] nums)
{
// 解法1:處理不為0的,再處理為0的
if (nums == null || nums.Length == 0)
return;
int index = 0;
for (int i = 0; i < nums.Length; i++)
{
if (nums[i] != 0)
nums[index++] = nums[i];
}
while (index < nums.Length)
{
nums[index++] = 0;
}
// 解法2:遇到不為0的 互換位置
int j = 0;
for (int i = 0; i < nums.Length; i++)
{
if (nums[i] != 0)
{
int temp = nums[i];
nums[i] = nums[j];
nums[j] = temp;
j++;
}
}
}
題目 官網(wǎng)鏈接 https://leetcode-cn.com/problems/climbing-stairs/
70. 爬樓梯
假設(shè)你正在爬樓梯。需要 n 階你才能到達(dá)樓頂。
每次你可以爬 1 或 2個(gè)臺(tái)階。你有多少種不同的方法可以爬到樓頂呢?
注意:給定 n 是一個(gè)正整數(shù)。
輸入: 2
輸出: 2
解釋: 有兩種方法可以爬到樓頂。
1. 1 階 + 1 階
2. 2 階
輸入: 3
輸出: 3
解釋: 有三種方法可以爬到樓頂。
1. 1 階 + 1 階 + 1 階
2. 1 階 + 2 階
3. 2 階 + 1 階
public int ClimbStairs(int n)
{
// // 解法1:遞歸(記憶化搜索)
// int[] memo = new int[n + 1];
// return helper(n, memo);
// // 解法2:動(dòng)態(tài)規(guī)劃
// if (n == 1)
// return 1;
// int[] dp = new int[n + 1];
// dp[1] = 1;
// dp[2] = 2;
// for (int i = 3; i <= n; i++)
// dp[i] = dp[i - 1] + dp[i - 2];
// return dp[n];
// 解法3:斐波那契數(shù)
if (n == 1)
return 1;
int first = 1;
int second = 2;
for (int i = 3; i <= n; i++)
{
int third = first + second;
first = second;
second = third;
}
return second;
}
public int helper(int n, int[] memo)
{
if (n <= 2)
return n;
if (memo[n] != 0)
return memo[n];
memo[n] = helper(n - 1, memo) + helper(n - 2, memo);
return memo[n];
}
感謝各位的閱讀,以上就是“C#移動(dòng)零和爬樓梯的實(shí)現(xiàn)方法是什么”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)C#移動(dòng)零和爬樓梯的實(shí)現(xiàn)方法是什么這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!
文章題目:C#移動(dòng)零和爬樓梯的實(shí)現(xiàn)方法是什么
瀏覽路徑:http://jinyejixie.com/article42/ijgsec.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護(hù)、外貿(mào)網(wǎng)站建設(shè)、定制開(kāi)發(fā)、手機(jī)網(wǎng)站建設(shè)、網(wǎng)站導(dǎo)航、網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)