数学归纳法通过递归函数在 c++++ 中得以实现,通过证明基本情况和归纳步骤,即可证明给定的命题对所有自然数成立。例如,上述代码证明了“所有自然数 n,n^2 + n + 41 是素数”。
用 C++ 递归函数演示数学归纳法
简介
数学归纳法是一种数学证明技术,用于证明对于所有自然数 n
的某个命题 P(n)
成立。它通过以下两个步骤进行:
-
基本情况:证明
P(1)
成立。 -
归纳步骤:假设
P(k)
对于某个自然数k
成立,并证明P(k+1)
也成立。
C++ 中的递归函数可以轻松而简洁地实现数学归纳法。
代码示例
考虑证明以下命题:
C++ 代码:
#include <iostream> // 递归函数来检查一个数字是否是素数 bool isPrime(int n) { // 基本情况:2 是素数 if (n <= 2) return true; // 归纳步骤:假设 n 是素数,检查 n+1 for (int i = 2; i <= n / 2; i++) { if (n % i == 0) return false; } return true; } int main() { // 对于 1 到 100 的每个数字 for (int i = 1; i <= 100; i++) { // 检查该数字是否满足我们的命题 if (isPrime(i * i + i + 41)) std::cout << i << "^2 + " << i << " + 41 is prime." << std::endl; } return 0; }