图解算法数据结构-LeetBook-回溯01_机械累加器

请设计一个机械累加器,计算从 1、2... 一直累加到目标数值 target 的总和。注意这是一个只能进行加法操作的程序,不具备乘除、if-else、switch-case、for 循环、while 循环,及条件判断语句等高级功能。

注意:不能用等差数列求和公式(用了乘法),也不能用pow()函数(用乘法实现)

公式法

cpp 复制代码
class Solution {
public:
    int mechanicalAccumulator(int target) {
        char a[target][target+1];
        return sizeof(a)>>1;
    }
};

在C++中,sizeof是一个运算符,用于获取数据类型或对象的大小(以字节 为单位)。它可以返回以下三种类型的值:

类型:返回指定类型的字节大小。

对象:返回对象在内存中占用的字节大小。

数组:返回整个数组在内存中占用的字节大小。

c++ 复制代码
#include <iostream>  
  
int main() {  
    int a;  
    double b;  
    char str[] = "Hello, World!";  
    std::cout << "Size of int: " << sizeof(a) << " bytes\n";  
    std::cout << "Size of double: " << sizeof(b) << " bytes\n";  
    std::cout << "Size of char array: " << sizeof(str) << " bytes\n";  
    return 0;  
}

输出:

c++ 复制代码
Size of int: 4 bytes  
Size of double: 8 bytes  
Size of char array: 13 bytes

需要注意的是,sizeof返回的是size_t类型,这是一种无符号整数类型,用于表示大小或索引。如果你需要将sizeof的结果转换为其他整数类型,可以使用类型转换操作符,例如(int)

由于等差数列求和公式是 ( a 1 + a n ) ∗ n / 2 (a_1 +a_n)* n / 2 (a1+an)∗n/2在本题中就是 ( 1 + n ) ∗ n / 2 (1 +n)* n / 2 (1+n)∗n/2

这里有两个问题,第一是乘法不用"*"怎么表示,第二是除法不用"/"怎么表示

这里的乘法的计算可以看作:计算一个元素大小为1字节的二维数组的总大小,而sizeof()刚好可以计算一个char类型或者bool类型数组的大小;用右移一位(>>1)表示除法

回溯

cpp 复制代码
class Solution {
public:
    int mechanicalAccumulator(int target) {
        (target > 1) && (target += mechanicalAccumulator(target-1));
        return target;
    }
};
相关推荐
田梓燊41 分钟前
力扣:23.合并 K 个升序链表
算法·leetcode·链表
re林檎1 小时前
算法札记——4.27
算法
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
数据牧羊人的成长笔记2 小时前
逻辑回归与Softmax回归
算法·回归·逻辑回归
郑州光合科技余经理2 小时前
同城O2O海外版二次开发实战:从支付网关到配送算法
开发语言·前端·后端·算法·架构·uni-app·php
Mrlxl.cn4 小时前
计算机网络——网络层
c语言·数据结构·计算机网络·考研
d111111111d5 小时前
STM32-UART封装问题解析
笔记·stm32·单片机·嵌入式硬件·学习·算法
寒秋花开曾相惜5 小时前
(学习笔记)4.2 逻辑设计和硬件控制语言HCL(4.2.1 逻辑门&4.2.2 组合电路和HCL布尔表达式)
linux·网络·数据结构·笔记·学习·fpga开发
Jiangxl~6 小时前
IP数据云如何为不同行业提供精准IP查询与风险防控解决方案?
网络·网络协议·tcp/ip·算法·ai·ip·安全架构
李伟_Li慢慢7 小时前
wolfram详解山峦算法
前端·算法