当前位置: 首页 > news >正文

C#经典算法面试题

C#经典算法面试题

递归算法

C#递归算法计算阶乘的方法

一个正整数的阶乘(factorial)是所有小于及等于该数的正整数的积,并且0的阶乘为1。自然数n的阶乘写作n!。1808年,基斯顿·卡曼引进这个表示法。

原理:亦即n!=1×2×3×…×(n-1)×n。阶乘亦可以递归方式定义:0!=1,n!=(n-1)!×n。

        /// <summary>/// C#递归算法计算阶乘的方法/// 一个正整数的阶乘(factorial)是所有小于及等于该数的正整数的积,并且0的阶乘为1。自然数n的阶乘写作n!。1808年,基斯顿·卡曼引进这个表示法。/// 亦即n!=1×2×3×...×(n-1)×n。阶乘亦可以递归方式定义:0!=1,n!=(n-1)!×n。/// 最终输出结果:120/// </summary>public static void RecursiveFactorial(){int result = Factorial(5);Console.WriteLine("5的阶乘为:" + result);//5!=120}public static int Factorial(int n){if (n == 0 || n == 1){return 1;}else{// 递归调用:当前数n乘以前面所有数的阶乘return n * Factorial(n - 1);}}

C#递归算法数组求

        /// <summary>/// 递归算法数组求/// 最终输出结果为:259/// </summary>public static void RecursiveArraySum(){int[] numbers = { 1, 88, 66, 4, 100 };int sum = ArraySum(numbers, 0);Console.WriteLine("数组元素的总和为:" + sum);}/// <summary>/// 计算数组元素的总和/// </summary>/// <param name="arr">arr</param>/// <param name="index">index</param>/// <returns></returns>public static int ArraySum(int[] arr, int index){if (index >= arr.Length){// 基本情况:数组为空或者已经遍历完所有元素return 0;}else{// 递归调用:当前元素加上剩余元素的总和return arr[index] + ArraySum(arr, index + 1);}}

C#使用递归算法来实现求解斐波纳契数列中第30位数的值

一列数的规则如下 : 1 、 1 、 2 、 3 、 5 、 8 、 13 、 21 、 34… 求第 30 位数是多少, 用递归算法实现。

        /// <summary>/// 使用递归算法来实现求解斐波纳契数列中第30位数的值/// 一列数的规则如下 : 1 、 1 、 2 、 3 、 5 、 8 、 13 、 21 、 34… 求第 30 位数是多少, 用递归算法实现/// 最终输出结果为:832040/// </summary>public static void FibonacciSum(){int n = 30;int result = Fibonacci(n);Console.WriteLine("第 " + n + "位斐波那契数是:" + result);}public static int Fibonacci(int n){if (n <= 0){return 0;}else if (n > 0 && n <= 2){return 1;}else{// 递归情况:调用自身计算前两个数字之和return Fibonacci(n - 1) + Fibonacci(n - 2);}}

相关文章:

  • LeetCode 解题思路 45(Hot 100)
  • 卷积神经网络的简单实战项目
  • C++ string的使用
  • 隔离端口配置
  • ArcGIS Pro图斑属性自动联动更新-在线卫星底图图斑采集
  • C语言结构体内存对齐使用场景
  • 【区块链】Uniswap之滑点(Slippage)
  • R8周:RNN实现阿尔茨海默病诊断
  • 软件代码签名证书SSL如何选择?
  • NoUniqueKey问题和Regular join介绍
  • UE5 脚部贴地不穿过地板方案
  • C++命名空间
  • USB接口的PCB设计
  • K8S - Helm 入门与实战 - 应用部署与依赖治理
  • Java 8 非对称加密代码示例
  • 《让内容“活”起来:Flutter社交应用瀑布流布局的破界实践》
  • 神经网络中之多类别分类:从基础到高级应用
  • Ollama本地部署大模型指南
  • 2025年国考行测 试卷结构和备考建议
  • uv全功能更新:统一管理Python项目、工具、脚本和环境的终极解决方案
  • 秦洪看盘|受阻回落,蓄积新做多能量
  • 巴基斯坦军方称印度袭击已致26死46伤
  • 《中国医药指南》就涉宫颈癌等论文出现男性病例致歉:辞退涉事编辑
  • “鱼米之乡”江苏兴化的产业哲学:以融合与创新重构价值链条
  • “五一”假期全社会跨区域人员流动量超14.65亿人次
  • 视觉周刊|劳动开创未来