C#移动零和爬楼梯的实现方法是什么
发表于:2025-01-31 作者:千家信息网编辑
千家信息网最后更新 2025年01月31日,这篇文章主要讲解了"C#移动零和爬楼梯的实现方法是什么",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"C#移动零和爬楼梯的实现方法是什么"吧!给定一个数
千家信息网最后更新 2025年01月31日C#移动零和爬楼梯的实现方法是什么
这篇文章主要讲解了"C#移动零和爬楼梯的实现方法是什么",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"C#移动零和爬楼梯的实现方法是什么"吧!
给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。
示例:
输入: [0,1,0,3,12]
输出: [1,3,12,0,0]
说明:
必须在原数组上操作,不能拷贝额外的数组。
尽量减少操作次数。
题解:
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++;
}
}
}
题目 官网链接 https://leetcode-cn.com/problems/climbing-stairs/
70. 爬楼梯
假设你正在爬楼梯。需要 n 阶你才能到达楼顶。
每次你可以爬 1 或 2个台阶。你有多少种不同的方法可以爬到楼顶呢?
注意:给定 n 是一个正整数。
示例 1:
输入: 2
输出: 2
解释: 有两种方法可以爬到楼顶。
1. 1 阶 + 1 阶
2. 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:动态规划
// 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:斐波那契数
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#移动零和爬楼梯的实现方法是什么"的内容了,经过本文的学习后,相信大家对C#移动零和爬楼梯的实现方法是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
方法
楼梯
移动
解法
C#
数组
楼顶
示例
学习
输入
输出
内容
题解
处理
解释
不同
位置
元素
函数
动态
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
华硕路由器服务器停止服务
软件开发阶段检查表
泰安定制软件开发解决方案
宏锐软件开发有限公司
严防手机网络安全问题招法
软件开发 发票 税率
华为服务器连接家用路由器
国产服务器怎么更改时间
面试常考软件开发流程
网络安全国外股票估值
芝罘区游戏软件开发公司电话
如何进行网络技术测试
网络安全认识消防器材教案
大智财务报表数据库代码
翼和沃南京网络技术有限公司
东莞微信软件开发设计
服务器怎么登微信
软件开发公司链接
网络安全法 解读培训
城市分站 数据库
HFC接入网络技术
分布式数据库事务方案
瑞庭网络技术后台
软件开发去大公司还是小公司
人间地狱游戏怎么增加服务器
安卓国服光遇服务器
计算机网络技术手册
数据库三大范型
湛江汽车软件开发咨询
服务器出现了问题什么办