求1+2+3+…+n

news/2024/7/3 0:23:28

 求1+2+3+…+n

【题目】:

求1+2+3+…+n。要求不能用乘法除法、for、while、if-else、switch-case等关键字以及条件判断语句A?B:C。

【解题思路】:

本题在简单问题上做了许多限制,需要使用排除法一步步导向答案。 1+2+...+(n-1)+n的计算方法主要有三种:平均计算、迭代、递归。

方法一: 平均计算 问题: 此计算必须使用 乘除法 ,因此本方法不可取,直接排除。

def sumNums(n):return (1 + n) * n // 2

方法二: 迭代 问题: 循环必须使用 while 或 for ,因此本方法不可取,直接排除。

def sumNums(n):res = 0for i in range(1, n + 1):res += ireturn res

方法三: 递归 问题: 终止条件需要使用 if ,因此本方法不可取。

思考: 除了 if 和 switch等判断语句外,是否有其他方法可用来终止递归?

def sumNums(n):if n == 1: return 1n += sumNums(n - 1)return n

逻辑运算符的短路效应: 常见的逻辑运算符有三种,即 “与 && ”,“或 ||”,“非 ! ” ;而其有重要的短路效应,如下所示:

if(A && B) // 若 A 为 false ,则 B 的判断不会执行(即短路),直接判定 A && B 为 false

if(A || B) // 若 A 为 true ,则 B 的判断不会执行(即短路),直接判定 A || B 为 true

本题需要实现 “当 n = 1时终止递归” 的需求,可通过短路效应实现。 n > 1 && sumNums(n - 1) // 当 n = 1 时 n > 1 不成立 ,此时 “短路” ,终止后续递归

复杂度分析:

  • 时间复杂度 O(n): 计算 n + (n-1) + ... + 2 + 1 需要开启 n 个递归函数。
  • 空间复杂度 O(n) : 递归深度达到 n ,系统使用 O(n) 大小的额外空间。

示例代码1:

class SUM(object):def sum(self, n):return n and n + self.sum(n - 1)#  test
obj = SUM()
n = 3
print(obj.sum(n))

运行结果:

示例代码2:

class SUM(object):def __init__(self):self.ret = 0def sum(self, n):n > 1 and self.sum(n - 1)self.ret += nreturn self.ret#  test
obj = SUM()
n = 100
print(obj.sum(n))

运行结果:


http://lihuaxi.xjx100.cn/news/266361.html

相关文章

清华大学刘知远组:文本分类任务中,将知识融入Prompt-tuning过程

点击上方“视学算法”,选择加"星标"或“置顶”重磅干货,第一时间送达©作者 | 刘兴贤学校 | 北京邮电大学硕士生研究方向 | 自然语言处理前两天看到刘知远老师组在 arxiv 上放出来了 Prompt-tuning 相关的新工作,这篇文章是将外…

强化学习是针对优化数据的监督学习?

作者 | Ben Eysenbach、Aviral Kumar、Abhishek Gupta 编译 | 凯隐出品 | AI科技大本营(ID:rgznai100)强化学习(RL)可以从两个不同的视角来看待:优化和动态规划。其中,诸如REINFORCE等通过计算不可微目标期…

WindowsServer2012史记7-茴香豆的五种写法和四种”显示计算机”的方法

消失的"计算机"?【这周九叔工作比较忙,还有其他琐事缠身,因此SystemCenter2012SP1系列的发布稍慢,抱歉了各位。】众所周知,WindowsServer2012和Windows8一样,默认桌面上是没有"计算机"…

Centos7.4安装kvm虚拟机(使用virt-manager管理)

2019独角兽企业重金招聘Python工程师标准>>> Centos7.4安装kvm虚拟机(使用virt-manager管理) 之前介绍了使用WebVirtMgr或Openstack来部署及管理kvm虚拟机,下面简单介绍centos7.4下使用virt-manager部署及管理kvm虚拟机的做法&…

模板方法模式——看看 JDK 和 Spring 是如何优雅复用代码的

Keeper导读:不管是我们学习并发编程中的 AQS,还是看 Spring 的源码,肯定都会遇到模板方法模式,它简直太常见了。前言模板,顾名思义,它是一个固定化、标准化的东西。模板方法模式是一种行为设计模式&#xf…

Linux Linux程序练习十一(网络编程大文件发送UDP版)

//网络编程发送端--大文件传输&#xff08;UDP&#xff09; #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <errno.h>#include <sys/types.h> #include <sys/socket.h> #include <n…

刚刚:2021软科世界大学学术排名发布!哈佛第一!国内有157所高校上榜!

点击上方“视学算法”&#xff0c;选择加"星标"或“置顶” 重磅干货&#xff0c;第一时间送达来源 | 软科刚刚&#xff08;2021年8月15日&#xff09;&#xff0c;全球领先的高等教育评价机构软科今日正式发布“2021软科世界大学学术排名”。排名展示了全球领先的100…

算法介绍

算法介绍 算法是计算机处理信息的本质&#xff0c;因为计算机程序本质上是一个算法来告诉计算机确切的步骤来执行一个指定的任务&#xff0c;一般的&#xff0c;当算法在处理信息时&#xff0c;会从输入设备或数据的存储地址来读取数据&#xff0c;把结果写入输出设备或某个存…