迭代对数求幂
Iterative logarithmic exponentiation
本文关键字:迭代 更新时间:2023-10-16
我最近搞砸了一次面试(手机屏幕上有collabedit)。问题是:编写一个求x^y的幂的迭代O(lgn)算法(x是二重,y>0是整数)。
我首先做了递归分治,并试图将其转换为迭代。。。我不能:S有没有一种方法可以将递归转换为迭代(尾部递归很容易,但递归函数有两个可能的递归调用,这取决于决定调用哪个调用的条件)?
展开的典型方法使用b的逐位表示。计算a1、a2,a4和a8等,并在每一步确定是否将其乘以总数。如图所示:
double result = 1;
double multiplier = a;
for (double multiplier = a; b != 0; multiplier *= multiplier, b /= 2) {
if (b % 2 == 1) {
result *= multiplier;
}
}
例如,要计算35,我们会注意到5有二进制表示101,所以我们会乘以31。
希望这能有所帮助!
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++中带有List类的迭代器Segfault
- 迭代时从向量和内存中删除对象
- 如何在c++迭代器类型中包装std::chrono
- 带过滤器的现代迭代c++集合
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- C++矢量迭代
- 集合上的输出迭代器:assign和increment迭代器
- Boost Spirit,获取迭代器内部语义动作
- 擦除while循环中迭代的元素
- 实现一个在集合上迭代的模板函数
- 对于set上的循环-获取next元素迭代器
- 在向量内的向量上迭代
- 为什么output_editor Concept不需要output_e迭代器标记
- TSP递归解的迭代形式
- c++17文件系统::recursive_directory迭代器()在mac上没有给出这样的目录,但在windows上
- 使用迭代器时如何访问对象在向量中的位置?
- std::vector::迭代器是否可以合法地作为指针
- 跟随整数索引列表的自定义类迭代器