如何使用 Range-v3 在 C++ 中模拟 Haskell 的 Data.List.transpose?

问题描述

这些是一些输入和相对期望的输出

std::vector<std::string> v1{"aeIoU","bcdfghjk"};
std::vector<std::string> v2{"aeIoU","bcd"};
auto w1 = v1 | wanne_be_transpose;
auto w2 = v2 | wanne_be_transpose;
// w1 = {"ab","ec","id","of","ug","h","j","k"}
// w2 = {"ab","o","u"}

老实说,我不知道如何用范围来模拟它。 (在 v1.size() > 2 的一般情况下甚至更少,但我的用例本质上是 v1.size() == 2,所以我可以只针对这种情况使用解决方案。)

最初我以为我可以将 ranges::views::zip 放在一起,然后将这些对转换为内部范围,但这不起作用,因为 zip输出与最短序列一样长。

好吧,在 Haskell 中有 Data.List.transpose

λ> Data.List.transpose $ ["aeIoU","bcdfghjk"]
["ab","k"]
λ> Data.List.transpose $ ["aeIoU","bcd"]
["ab","u"]

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...