当前位置:  开发笔记 > 编程语言 > 正文

在编译时将std :: array的每个元素相乘

如何解决《在编译时将std::array的每个元素相乘》经验,为你挑选了1个好方法。

我想将一个转换std::array为另一个std::array,将每个元素乘以一个特定的数字.

我现在拥有的东西显然不起作用:

#include 
#include 
#include 

template 
constexpr std::array multiply(std::array const &src,
                                  std::index_sequence) {
    return std::array{{src[Is]...}}; // How can I multiply each of src's elements?
}

int main(int argc, char *argv[]) {
    constexpr std::array arr = {1, 2, 3};
    constexpr auto t = multiply(arr, std::make_index_sequence<3>{});
    for (auto &el : t) std::cout << el << std::endl;
    return 0;
}

我的问题是:如何在编译时迭代每个元素,或者如何在编译时应用相同的函数(在我的情况下:乘以2)?



1> 101010..:

您可以通过以下方式执行此操作:

template
constexpr T mult(T const &a, T const &b) { return a * b; }

template 
constexpr std::array multiply(std::array const &src, 
                                    std::index_sequence) {
  return std::array{{mult(src[Is], src[Is])...}}; 
}

现场演示

或者,如果您想乘以一个数字,您可以更改为:

template
constexpr T mult(T const &a, T const &b) { return a * b; }

template 
constexpr std::array multiply(std::array const &src, 
                                    std::index_sequence, T const &mul) {
  return std::array{{mult(src[Is], mul)...}}; 
}

现场演示

正如cppreference中所解释的那样:

后跟省略号的模式,其中至少一个参数包的名称至少出现一次,将扩展为模式的零个或多个以逗号分隔的实例化,其中参数包的名称由每个类型替换从包装,按顺序.包扩展只能在包扩展上下文中发生.这些基本上是:

支持初始化

初始化列表

聚合初始化

函数调用

数组初始化

编辑:

正如TC在评论中指出的那样,你也可以这么简单:

template 
constexpr std::array multiply(std::array const &src, std::index_sequence, T const &mul) {
  return std::array{{(src[Is] * mul)...}}; 
}

现场演示


`{{(src [Is]*mul)...}}`甚至`{{src [Is]*mul ...}}`工作正常.使用额外功能毫无意义.
推荐阅读
mobiledu2402851373
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有