两层数组广度优先数据遍历

  当需要轮训取多个分类数据的时候,每个分类一个数组,每个分类取一个再取下一个。

遍历方式总结如下:

  

List<List<String>> list = new ArrayList<List<String>>();

int jLeng = 0;
for (int i = 0; i < skuList.size(); i++) {
String skuInfo = skuList.get(i);
List<String> skuInfoList = resolveSku(skuInfo);
if (skuInfoList != null && skuInfoList.size() > jLeng) 
jLeng = skuInfoList.size();
if(skuInfoList!=null)
list.add(skuInfoList);
}

List<String> result = new ArrayList<String>();

for (int j = 0; j < jLeng; j++) {
for (int i = 0; i < list.size(); i++) {
List<String> skuInfoList = list.get(i);
if (skuInfoList == null || j >= skuInfoList.size())
continue;
String sku = skuInfoList.get(j);
if(!result.contains(sku))
result.add(sku);
if (result.size() == length) {
return result;
}
}
}

posted @   杉枫  阅读(407)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
点击右上角即可分享
微信分享提示