C++ 递归与面向对象编程基础

小万哥
• 阅读 518

C++ 递归

递归是一种使函数调用自身的技术。这种技术提供了一种将复杂问题分解为简单问题的方法,从而更容易解决问题。

递归可能有点难以理解。理解其工作原理的最佳方法是通过实验来尝试。

递归示例

将两个数字相加很容易做到,但将一系列数字相加就更复杂了。在下面的示例中,通过将其分解为将两个数字相加的简单任务,使用递归将一系列数字相加:

int sum(int k) {
  if (k > 0) {
    return k + sum(k - 1);
  } else {
    return 0;
  }
}

int main() {
  int result = sum(10);
  cout << result;
  return 0;
}

示例解释

当调用 sum() 函数时,它将参数 k 加到小于 k 的所有数字的和中,并返回结果。当 k 变为 0 时,函数只返回 0。运行时,程序按照以下步骤执行:

10 + sum(9) 10 + ( 9 + sum(8) ) 10 + ( 9 + ( 8 + sum(7) ) ) ... 10 + 9 + 8 + 7 + 6 + 5 + 4 + 3 + 2 + 1 + sum(0) 10 + 9 + 8 + 7 + 6 + 5 + 4 + 3 + 2 + 1 + 0

由于在 k 为 0 时函数不会调用自身,程序在此处停止并返回结果。

注意事项

开发人员在使用递归时应非常小心,因为很容易陷入编写永远不会终止的函数,或者使用过多的内存或处理器资源。然而,当正确编写时,递归可以是一种非常高效和数学上优雅的编程方法。

总结

递归是一种强大的工具,可以用于解决各种编程问题。但是,重要的是要谨慎使用递归,并确保您的代码不会陷入无限循环。

C++ 面向对象编程

C++ 面向对象编程(C++ OOP)是将面向对象编程(OOP)概念应用于 C++ 编程语言的过程。它是一种编程范式,专注于创建可重用、可维护和易于理解的代码。

面向对象编程与过程式编程的区别

面向对象编程与过程式编程的主要区别在于,它将程序分解为可互动的对象,而不是一系列过程或函数。每个对象都有自己的数据(属性)和行为(方法),并封装在一个类中。这使得代码更易于组织、理解和维护。

以下是面向对象编程的一些主要优势:

  • 代码可重用性: OOP 鼓励代码重用,因为它允许您创建可用于多个程序的类和对象。这可以节省开发时间并提高代码质量。
  • 代码维护性: OOP 代码通常更容易维护,因为它们更易于理解和修改。类和对象的封装特性有助于隔离代码更改,从而减少意外影响。
  • 代码可扩展性: OOP 代码通常更易于扩展,因为您可以通过添加新类或方法来轻松添加新功能。

C++ 中的基本 OOP 概念

C++ OOP 的核心是以下概念:

  • 类: 类是用于创建对象的蓝图。它定义了对象的属性和方法。
  • 对象: 对象是类的实例。它包含类的属性值并可以调用类的方法。
  • 属性: 属性是对象的特征或数据。
  • 方法: 方法是对象的函数或行为。

创建 C++ 类

要创建 C++ 类,请使用 class 关键字后跟类名:

class MyClass {
  // 类成员定义
};

类成员可以包括属性和方法。属性是类的变量,方法是类的函数。

创建 C++ 对象

要创建 C++ 对象,请使用类名后跟对象名:

MyClass myObj;

这将创建一个名为 myObjMyClass 类对象。

访问类成员

可以使用点语法(.)访问类对象的属性和方法:

myObj.myProperty; // 访问属性
myObj.myMethod(); // 调用方法

示例:创建一个简单的类

以下是一个创建名为 Car 的简单类的示例:

class Car {
public:
  string brand;
  string model;
  int year;

  void startEngine() {
    cout << "Engine started!" << endl;
  }

  void stopEngine() {
    cout << "Engine stopped!" << endl;
  }
};

此类定义了三个属性:brandmodelyear,以及两个方法:startEngine()stopEngine()

要创建 Car 类的对象并调用其方法,可以使用以下代码:

Car myCar;

myCar.brand = "Ford";
myCar.model = "Mustang";
myCar.year = 1967;

myCar.startEngine();
myCar.stopEngine();

此代码将创建一个名为 myCarCar 对象,设置其属性并调用其方法。

总结

C++ 面向对象编程是一种强大的工具,可用于创建可维护、可扩展和易于理解的代码。通过理解类、对象、属性和方法等基本概念,您可以开始构建面向对象的 C++ 程序。

最后

为了方便其他设备和平台的小伙伴观看往期文章:

微信公众号搜索:Let us Coding,关注后即可获取最新文章推送

看完如果觉得有帮助,欢迎点赞、收藏、关注

点赞
收藏
评论区
推荐文章
凯特林 凯特林
3年前
浅谈JS中的递归
一、递归递归(英语:Recursion)在数学与计算机科学中,是指在函数的定义中使用函数自身的方法在函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数其核心思想是把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解一般来说,递归需要有边界条件、递归前进阶段和递归返回阶段。当边界条件不满足时,递归前进;当边界条件满
徐小夕 徐小夕
4年前
如何优雅的使用javascript递归画一棵结构树
递归和尾递归简单的说,递归就是函数自己调用自己,它做为一种算法在程序设计语言中广泛应用。其核心思想是把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的
Irene181 Irene181
3年前
一篇文章带你了解Python递归函数
一、什么是递归函数?在函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。二、函数的递归调用原理实际上递归函数是在栈内存上递归执行的,每次递归执行一次就会耗费一些栈内存。栈内存的大小是限制递归深度的重要因素三、案例分析1.求阶乘计算阶乘n!1x2x3x…xn,可以用
CuterCorley CuterCorley
3年前
C语言基础习题50例(六)26-30
习题26利用递归方法求5。实现思路:使用递归。代码如下:cinclude<stdio.hintmain(){intrec(intn);intresultrec(5);printf("5%d\n",result);return0;}intrec(intn){if(n1||n
Wesley13 Wesley13
3年前
FLV文件格式
1.        FLV文件对齐方式FLV文件以大端对齐方式存放多字节整型。如存放数字无符号16位的数字300(0x012C),那么在FLV文件中存放的顺序是:|0x01|0x2C|。如果是无符号32位数字300(0x0000012C),那么在FLV文件中的存放顺序是:|0x00|0x00|0x00|0x01|0x2C。2.  
Wesley13 Wesley13
3年前
C语言中的状态机设计
本文不是关于软件状态机的最佳设计分解实践的教程。我将重点关注状态机代码和简单的示例,这些示例具有足够的复杂性,以便于理解特性和用法。背景大多数程序员常用的设计技术是有限状态机(FSM)。设计人员使用此编程结构将复杂的问题分解为可管理的状态和状态转换。有无数种实现状态机的方法。A switch语句提供了状态机最容易实现和最常见的版本之一。
Stella981 Stella981
3年前
Python之函数递归与迭代
函数递归:  定义:程序调用自身的编程技巧称为递归(recursion)。递归做为一种算法在程序设计语言中广泛应用。一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量
Wesley13 Wesley13
3年前
JAVA学习入门篇_递归结构
递归结构递归是一种常见的解决问题的方法,即把问题逐渐简单化。递归的基本思想就是“自己调用自己”,一个使用递归技术的方法将会直接或者间接的调用自己。​利用递归可以用简单的程序来解决一些复杂的问题。比如:斐波那契数列的计算、汉诺塔、快排等问题。​递归结构包括两个部分:​1.定义递归头。解答:什么
小万哥 小万哥
1年前
C 语言运算符详解
C语言中的运算符运算符用于对变量和值进行操作。在下面的示例中,我们使用运算符将两个值相加:cintmyNum10050;虽然运算符通常用于将两个值相加,就像上面的示例一样,它还可以用于将变量和值相加,或者将变量和另一个变量相加:cintsum1100
小万哥 小万哥
10个月前
C++ 运算符全解析:从基础概念到实际应用
C运算符运算符用于对变量和值执行操作。在下面的示例中,我们使用运算符将两个值相加:cppintx10050;虽然运算符经常用于将两个值相加,就像上面的示例一样,但它也可以用于将变量和一个值相加,或者将一个变量和另一个变量相加:cppintsum1