我有CatalogProduct(id: String, name: String)
类来声明产品
我下面有两个列表:
val newestCatalogProductList = mutableListOf<CatalogProduct>()
newestCatalogProductList.add(CatalogProduct("A1", "Apple"))
newestCatalogProductList.add(CatalogProduct("A2", "Banana"))
newestCatalogProductList.add(CatalogProduct("A3", "Orange"))
newestCatalogProductList.add(CatalogProduct("A4", "Pineapple"))
val popularCatalogProductList = mutableListOf<CatalogProduct>()
popularCatalogProductList.add(CatalogProduct("A5", "Milk"))
popularCatalogProductList.add(CatalogProduct("A6", "Sugar"))
popularCatalogProductList.add(CatalogProduct("A7", "Salt"))
popularCatalogProductList.add(CatalogProduct("A8", "Sand"))
我通过以下代码成功合并了两个列表:
newestCatalogProductList.union(popularCatalogProductList)
但是,我无法按预期订购交错的合并列表:
CatalogProduct("A1", "Apple")
CatalogProduct("A5", "Milk")
CatalogProduct("A2", "Banana")
CatalogProduct("A6", "Sugar")
CatalogProduct("A3", "Orange")
CatalogProduct("A7", "Salt")
CatalogProduct("A4", "Pineapple")
CatalogProduct("A8", "Sand")
我开始学习科特林。如果您可以解释或创建示例或给我参考链接,请帮助我。所以,我谢谢你。
答案 0 :(得分:0)
您可以压缩列表以将具有与两个项目的列表相同的索引的项目配对,然后将它们展平:
val interleaved = newestCatalogProductList.zip(popularCatalogProductList) { a, b -> listOf(a, b) }
.flatten()
如果其中一个列表可能更长,则您可能希望保留更长列表中的其余项。在这种情况下,您可以通过以下方式手动压缩项目:
val interleaved2 = mutableListOf<CatalogProduct>()
val first = newestCatalogProductList.iterator()
val second = popularCatalogProductList.iterator()
while (interleaved2.size < newestCatalogProductList.size + popularCatalogProductList.size){
if (first.hasNext()) interleaved2.add(first.next())
if (second.hasNext()) interleaved2.add(second.next())
}