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

【C/PTA —— 11.函数2(课外实践)】

C/PTA —— 11.函数2(课外实践)

  • 一.函数题
    • 6-1 计算A[n]=1/(1 + A[n-1])
    • 6-2 递归实现顺序输出整数
    • 6-3 自然数的位数(递归版)
    • 6-4 分治法求解金块问题
    • 6-5 汉诺塔
    • 6-6 重复显示字符(递归版)
    • 6-7 显示平行四边形(右)(递归版)
  • 二.编程题
    • 7-2 N阶楼梯上楼问题

一.函数题

6-1 计算A[n]=1/(1 + A[n-1])

在这里插入图片描述

float fun(int n)
{if (n == 1)return 1;return 1 / (1 + fun(n - 1));
}

6-2 递归实现顺序输出整数

在这里插入图片描述

void printdigits(int n)
{int count = 0;int num1 = 0;num1 = n;if (n == 0){printf("0");return 0;}while (n){n /= 10;count++;}int num[100] = { 0 };n = num1;int count1 = 0;while (n){num[count1++] = n % 10;n /= 10;}for (int i = count1 - 1; i >= 0; i--){printf("%d\n", num[i]);}
}

6-3 自然数的位数(递归版)

在这里插入图片描述

int NumDigit(int number)
{if (number == 0)return 0;else if (number / 10 == 0)return 1;elsereturn NumDigit(number / 10) + 1;
}

6-4 分治法求解金块问题

在这里插入图片描述

int max(int a[], int m, int n) {int i;int max = a[0];for (i = m; i < n + 1; i++) {if (a[i] > max) {max = a[i];}}return max;
}int min(int a[], int m, int n) {int i;int min = a[0];for (i = m; i < n + 1; i++) {if (a[i] < min) {min = a[i];}}return min;
}

6-5 汉诺塔

在这里插入图片描述

void hanoi(int n, char from, char to, char by)
{void move(char x, char y);if (n == 1)move(from, to);else{hanoi(n - 1, from, by, to);move(from, to);hanoi(n - 1, by, to, from);}
}void move(char x, char y)
{printf("%c->%c\n",x,y);
}

6-6 重复显示字符(递归版)

在这里插入图片描述

void Show(int number, char symbol)
{void Print(char ch);if (number <= 0)return;if (number == 1)Print(symbol);else{Show(number - 1, symbol);Print(symbol);}
}void Print(char ch)
{printf("%c", ch);
}

6-7 显示平行四边形(右)(递归版)

在这里插入图片描述

void RtPara(int width, int height, char symbol)
{void PrintSpace(int number);if (width <= 0 || height <= 0)return;else{PrintSpace(height - 1);Show(width, symbol);putchar('\n');RtPara(width, height - 1, symbol);}
}void PrintSpace(int number)
{if (number <= 0)return;else{printf(" ");PrintSpace(number - 1);}
}

二.编程题

7-2 N阶楼梯上楼问题

在这里插入图片描述

int ClimbStairs(int number)
{if (number == 1)return 1;else if (number == 2)return 2;else{int dp[number+1];dp[1] = 1;dp[2] = 2;int i = 0;for (i = 3; i <= number; i++){dp[i] = dp[i - 1] + dp[i - 2];}return dp[number];}
}int main()
{int n = 0;int ways = 0;scanf("%d", &n);ways = ClimbStairs(n);printf("%d\n", ways);
}
http://www.lryc.cn/news/242083.html

相关文章:

  • 2023 Unite 大会关于“Muse“ AI 大模型训练
  • Day28|Leetcode 93. 复原 IP 地址 Leetcode 78. 子集 Leetcode 90. 子集 II
  • 【Java 进阶篇】Jedis 操作 String:Redis中的基础数据类型
  • MySQL 8 配置文件详解与最佳实践
  • K8s client go 创建CRD的informer
  • 使用jmx_exporter监控Kafka
  • 什么是网络爬虫技术?它的重要用途有哪些?
  • Android MemoryFile 共享内存
  • 【lua】记录函数名和参数(为了延后执行)
  • 2023.11.22 数据仓库2-维度建模
  • pycharm 创建的django目录和命令行创建的django再使用pycharm打开的目录对比截图 及相关
  • 【Pytorch】Visualization of Fature Maps(2)
  • 【目标检测】保姆级别教程从零开始实现基于Yolov8的一次性筷子计数
  • 笔记:内网渗透流程之信息收集
  • 【2023.11.23】JDBC基本连接语法学习➹
  • ubuntu 安装python3.13
  • OpenCV数据类型及CV_16UC1深度图ros订阅
  • 华清远见嵌入式学习——网络编程——小项目
  • 分库分表、分布式数据库、MPP
  • 浅学指针(2)数组函数传值调用
  • C++之unordered_map/set的使用
  • docker打包chatpdf(自写)
  • shell基础
  • 力扣1038. 从二叉搜索树到更大和树(java,树的中序遍历解法)
  • 使用正则表达式来判断一个字符串只是否包含数字
  • C#Wpf关于日志的相关功能扩展
  • 亚马逊云科技AI创新应用下的托管在AWS上的数据可视化工具—— Amazon QuickSight
  • MySQL安全性:用户认证、防范SQL注入和SSL/TLS配置详解
  • EMG肌肉信号处理合集 (一)
  • 学自动化测试?我劝你还是算了吧。。。