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

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

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

一.函数题

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

c 复制代码
float fun(int n)
{
	if (n == 1)
		return 1;
	return 1 / (1 + fun(n - 1));
}

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

c 复制代码
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 自然数的位数(递归版)

c 复制代码
int NumDigit(int number)
{
    if (number == 0)
        return 0;
    else if (number / 10 == 0)
        return 1;
    else
        return NumDigit(number / 10) + 1;
}

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

c 复制代码
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 汉诺塔

c 复制代码
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 重复显示字符(递归版)

c 复制代码
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 显示平行四边形(右)(递归版)

c 复制代码
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阶楼梯上楼问题

c 复制代码
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);
}
相关推荐
2501_924952695 分钟前
C++中的枚举类高级用法
开发语言·c++·算法
2401_873204657 分钟前
代码覆盖率工具实战
开发语言·c++·算法
少司府10 分钟前
C++基础入门:第一个C++程序
java·c语言·开发语言·c++·ide
不染尘.10 分钟前
欧拉路径算法
开发语言·数据结构·c++·算法·图论
黎阳之光23 分钟前
黎阳之光:数智技术赋能水利“平急两用” 筑牢水利工程安全防线
大数据·人工智能·算法·安全·数字孪生
WG_1724 分钟前
Linux44+45:日志和线程池
算法
️是7839 分钟前
信息奥赛一本通—编程启蒙(3345:【例60.2】 约瑟夫问题)
开发语言·c++·算法
add45a1 小时前
C++中的智能指针详解
开发语言·c++·算法
做科研的周师兄1 小时前
巴音河中下游灌溉草地空间分布数据集(2020年)
大数据·人工智能·算法·机器学习·数据挖掘·聚类
闻缺陷则喜何志丹1 小时前
【分治法 前缀和】P8572 [JRKSJ R6] Eltaw|普及+
c++·算法·前缀和·洛谷·分治法