C语言第三十练——递归求解1+2+……+n

简介: C语言第三十练——递归求解1+2+……+n

第三十练

使用递归的方法计算1+2+3+……+n的结果

要求:1、输入数字n 2、输出加法的结果

第二十九练答案

三分搜索算法可以用于在连续区间上寻找函数的最小值。在这个问题中,我们可以使用三分搜索来找到最短时间。我们可以假设人在线段 AB 上行走的时间为 ( t_{AB} ),然后通过三分搜索找到使得总时间最小的 ( t_{AB} )。

以下是使用三分搜索算法的 C 语言程序:

#include <stdio.h>
#include <math.h>

// Function to calculate total time given t_AB
double calculateTotalTime(double t_AB, double L_AB, double L_CD, double P, double Q) {
    double t_CD = (L_CD - P * t_AB) / Q;
    return t_AB + t_CD;
}

// Function for three-section search
double ternarySearch(double L_AB, double L_CD, double P, double Q) {
    double left = 0.0;
    double right = L_AB;

    while (right - left > 1e-9) {
        double mid1 = left + (right - left) / 3;
        double mid2 = right - (right - left) / 3;

        double time1 = calculateTotalTime(mid1, L_AB, L_CD, P, Q);
        double time2 = calculateTotalTime(mid2, L_AB, L_CD, P, Q);

        if (time1 < time2) {
            right = mid2;
        } else {
            left = mid1;
        }
    }

    return calculateTotalTime((left + right) / 2, L_AB, L_CD, P, Q);
}

int main() {
    double L_AB, L_CD, P, Q;

    // Input lengths and speeds
    printf("Enter length of AB: ");
    scanf("%lf", &L_AB);

    printf("Enter length of CD: ");
    scanf("%lf", &L_CD);

    printf("Enter speed on AB: ");
    scanf("%lf", &P);

    printf("Enter speed on CD: ");
    scanf("%lf", &Q);

    // Calculate and print the minimum time using ternary search
    double result = ternarySearch(L_AB, L_CD, P, Q);
    printf("Minimum time: %lf\n", result);

    return 0;
}

这个程序使用了三分搜索算法,通过调用 ternarySearch 函数找到人从 A 点到 D 点的最短时间。用户需要输入线段 AB 和 CD 的长度以及在线段 AB 和 CD 上的速度。程序将输出最短时间。请注意,这里的 calculateTotalTime 函数用于计算给定 ( t_{AB} ) 时的总时间。

答案和解析会在次日公布

注意事项

编写代码的时候,需要注意以下几点问题:

  • 头文件的引用需要放在代码的最顶部
  • 每个C语言程序中必须包含一个 main函数
  • void main(){}
  • int main(){return 0;}
  • C语言中每一行的结尾处必须要使用分号结尾
  • C语言中的引号需要使用双引号,双引号都是以一对一对的情况出现的
  • 在scanf键盘输入代码中,要使用 & 加变量名来读取一个键盘输入
  • 赋值语句是将右边的值赋给左边的变量,顺序不能反了
  • 需要注意代码的缩进格式,缩进为4个空格或者一个tab键为一组,但是要保证整篇代码里面风格一致,要么都是4个空格缩进,要么都是使用一个tab进行缩进
  • 需要养成随手保存的习惯,保存的快捷键一般是 ctrl + s
  • 注意大括号的使用,大括号是代码块,代表了一个块的代码是放在一起的
  • 注意整数型和实数型的转换,如果将实数赋值给一个整形变量,那么实数的小数部分将会被舍去;
  • 注意除法中,如果除数和被除数都是整数,那么结果也会是一个整数,小数部分会自动舍弃
  • 成对出现的标点符号
  • 单引号,双引号,小括号,中括号,大括号等,一般不单独出现
  • 如果代码有问题,然后附近又刚好有这些成对符号,请着重关注
  • 定义变量时,该打的逗号应该打上,不能写掉了
  • 编写++符号时,不要误写成了ff
  • 一个程序里面只能有一个main函数,除了main函数的其他函数都不能叫这个名字
  • 在调用函数时,入参都是使用的逗号隔开,一定不要使用分号隔开
  • 换行符是\n,不能错误写成/n
  • 输入输出格式化
  • %d对应整数
  • %c对应字符
  • %f对应实数
  • 不要写错或者写漏了
  • if条件语句当前行不能加分号,不然这个语句就没有意义了

更多

欢迎来到C语言每日一练服务!

在现代技术的飞速发展中,编程已经成为一项不可或缺的技能。C语言作为一门经典的编程语言,奠定了计算机科学的基石,为学习其他编程语言打下了坚实的基础。为了帮助大家更好地掌握C语言,我们特别推出了每日一练服务,旨在提供系统性、全面性的学习支持。

我们的服务特点包括:

  1. 日常练习题目: 每天我们会提供一道C语言练习题目,涵盖基础知识、算法、数据结构等多个领域。这些题目既有难度,又具有实际应用价值,帮助你锻炼编程技能。
  2. 详细解析: 我们不仅提供每道题的标准答案,还会提供详细的解析和优秀代码示例。通过对解题思路的深入剖析,你能够更好地理解和掌握各种编程技巧。
  3. 互动学习社区: 通过微信文章评论区建立了一个互动学习社区,供学员们交流讨论。你可以在这里提问问题、分享经验,与其他学员一起成长。
  4. 个性化学习建议: 根据你的学习表现,我们会为你推荐相应难度的练习题,确保你的学习过程既具挑战性,又不至于过于困难,保持学习的动力和兴趣。

参与每日一练的好处:

  • 持续学习提升技能: 每日坚持练习,你的编程技能将会得到持续提升,不断进步。
  • 增强自信心: 通过解决各种类型的问题,你将建立起对自己技能的信心,更加轻松应对编程挑战。
  • 拓宽思路: 每道题都是一个小挑战,通过解决这些问题,你将培养出灵活的思维,更好地应对实际编程工作中的挑战。
  • 为未来发展奠定基础: 无论你是初学者还是有一定经验的程序员,C语言每日一练都将为你未来的编程发展奠定坚实的基础。

加入我们的C语言每日一练服务,一起挑战编程难题,不断提升自己,走向编程高手的道路!

目录
相关文章
|
1月前
|
机器学习/深度学习 C语言
九/十:《初学C语言》— 扫雷游戏实现和函数递归基础
【8月更文挑战第5天】本篇文章用C语言采用多文件编写实现了一个基础的扫雷游戏(附源码),并讲解了关于函数递归的基础概念及其相对应的习题练习(附源码)
32 1
九/十:《初学C语言》— 扫雷游戏实现和函数递归基础
|
19天前
|
机器学习/深度学习 C语言
【C语言篇】递归详细介绍(基础概念习题及汉诺塔等进阶问题)
要保持最小的步数,每一次汉诺塔问题(无论是最初还是递归过程中的),如果此时初始柱盘子数为偶数,我们第一步是把最上面的盘子移动到中转柱,如果为奇数,我们第一步则是将其移动到目标柱。
【C语言篇】递归详细介绍(基础概念习题及汉诺塔等进阶问题)
|
25天前
|
C语言
C语言中的递归
C语言中的递归
|
17天前
|
算法 编译器 C语言
【C语言】递归
【C语言】递归
11 0
|
2月前
|
存储 编译器 C语言
|
3月前
|
C语言
C语言--函数递归与迭代
C语言--函数递归与迭代
|
3月前
|
机器学习/深度学习 算法 C语言
详细介绍递归算法在 C 语言中的应用,包括递归的基本概念、特点、实现方法以及实际应用案例
【6月更文挑战第15天】递归算法在C语言中是强大力量的体现,通过函数调用自身解决复杂问题。递归涉及基本概念如自调用、终止条件及栈空间管理。在C中实现递归需定义递归函数,分解问题并设定停止条件。阶乘和斐波那契数列是经典应用示例,展示了递归的优雅与效率。然而,递归可能导致栈溢出,需注意优化。学习递归深化了对“分而治之”策略的理解。**
50 7
TU^
|
3月前
|
机器学习/深度学习 C语言
C语言之函数递归
C语言之函数递归
TU^
24 1
|
2月前
|
存储 算法 程序员
C语言编程—递归
递归是函数自我调用的编程技术,常用于解决分治问题,如计算阶乘和斐波那契数列。示例中展示了C语言的阶乘和斐波那契数列递归实现。递归需满足:问题可转化为规模更小的同类问题,存在结束条件以防止无限循环,并可能消耗大量时间和栈空间。栈用于存储函数调用信息,过多递归可能导致栈溢出。递归虽简洁,但非最优效率选择,递推算法通常是更好的替代方案。
33 0
|
3月前
|
C语言
【c语言】汉诺塔问题详解(c语言递归函数)
【c语言】汉诺塔问题详解(c语言递归函数)
18 0