Mathematica 有一个名为Range[]
的函数,它执行以下操作:
Range[0, 10]
Range[-10, 0]
它打印的Ant:
{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
{-10, -9, -8, -7, -6, -5, -4, -3, -2, -1, 0}
C ++有这样的功能吗?
答案 0 :(得分:9)
标准库中没有,但来自boost::range
:
#include <iostream>
#include <iterator>
#include <boost/range/irange.hpp>
#include <boost/range/algorithm/copy.hpp>
int main()
{
boost::copy(boost::irange(0, 11),
std::ostream_iterator<int>(std::cout, " "));
}
输出: 0 1 2 3 4 5 6 7 8 9 10
答案 1 :(得分:7)
似乎很容易创建一个。
std::vector<int> range(int from, int to) {
std::vector<int> result;
result.reserve(to-from+1);
for (int i = from; i <= to; ++i) {
result.push_back(i);
}
return result;
}
答案 2 :(得分:4)
为了完整起见,以下是使用C ++ 11标准库和 lambdas 的方法:
vector<int> v;
int counter = -3; // The initial value
generate_n(
back_inserter(v) // Where to insert
, 10 // how many items
, [&counter] () -> int { return counter++; });
答案 3 :(得分:2)
只有两个库提供 lazy 和 O(1)内存数值范围:
使用SCC(C ++ REPL)和RO:
scc 'range(0,10)'
{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
scc 'range(-10,0)'
{-10, -9, -8, -7, -6, -5, -4, -3, -2, -1, 0}