suchen

Heim  >  Fragen und Antworten  >  Hauptteil

javascript - Gibt es eine einfachere Möglichkeit, die Elemente einer Sammlung gleichmäßig auf ein anderes Array-Objekt zu verteilen?

  1. Array A=[„G“, „D“, „B“, „H“], die Anzahl der Elemente ist variabel und der Elementinhalt kann ein beliebiges Zeichen sein

  2. Setze B=[{"id":a",item:""},{"id":a=b",item:""}], variable Menge, feste Struktur

  3. Jetzt müssen wir die Elemente in A gleichmäßig auf die Elemente in B verteilen. Wenn es mehrere gibt, trennen Sie sie durch Kommas.

  4. Wenn die Anzahl der Elemente in A kleiner oder größer als die Länge von B ist, ist es nur erforderlich, dass alle A in B erscheinen. Die Elemente in Satz B müssen mindestens einem Element zugeordnet werden, vorzugsweise gleichmäßig, aber jeweils Artikel in Set B muss mindestens einem Element zugeordnet sein. Ein Artikel darf keine doppelten Elemente haben

  5. Gibt es einen einfacheren Weg?
phpcn_u1582phpcn_u15822789 Tage vor669

Antworte allen(2)Ich werde antworten

  • 世界只因有你

    世界只因有你2017-05-17 10:11:17

    已经解决了

    
    import com.google.common.collect.Lists;
    import com.google.common.collect.Maps;
    import com.google.common.collect.Sets;
    import org.apache.commons.collections.CollectionUtils;
    import org.apache.commons.lang3.RandomStringUtils;
    import org.apache.commons.lang3.RandomUtils;
    import org.apache.commons.lang3.StringUtils;
    
    import java.util.HashMap;
    import java.util.List;
    import java.util.Map;
    import java.util.Set;
    
    /**
     * Created by YSTYLE on 2017-04-17 0017.
     */
    public class TEst {
    
        private static List<String> list = Lists.newArrayList();
        private static List<Map> los = Lists.newArrayList();
    
        public static void main(String[] args) {
            init();
            List<String> augmented = list;
            int groupCount = los.size();
            if (list.size() < groupCount){
                augmented = Augmented(list, groupCount);
            }
            List<List<String>> chunk = chunk2(augmented, groupCount);
            for (int i = 0; i < los.size(); i++) {
                los.get(i).put("item", StringUtils.join(chunk.get(i),",") );
            }
            System.out.println(los);
        }
        // 初始化测试数据
        private static void init (){
            int losCount = RandomUtils.nextInt(1,10);
            int listCount = RandomUtils.nextInt(1,10);
            for (int i = 0; i < listCount ; i++) {
                list.add(RandomStringUtils.randomAlphabetic(4));
            }
            for (int i = 0; i <  losCount; i++) {
                Map<String,Integer> map = new HashMap<String, Integer>();
                map.put("id",RandomUtils.nextInt(10000,99999));
                los.add(map);
            }
            System.out.println("生成的数组: " + list+"  数量: "+listCount);
            System.out.println("生成的对象数量: " + los.size());
        }
    
        // 分组数据
        public static <T> List<List<T>> chunk2(List<T> list, int group){
            if (CollectionUtils.isEmpty(list)){
                return Lists.newArrayList();
            }
            List<List<T>> result = Lists.newArrayList();
            Map<Integer,Set<T>> temp = Maps.newHashMap();
            for (int i = 0; i < list.size(); i++) {
                if (temp.containsKey(i%group)) {
                    Set<T> ts = temp.get(i % group);
                    ts.add(list.get(i));
                    temp.put(i%group,ts);
                }else {
                    Set<T> ts = Sets.newHashSet();
                    ts.add(list.get(i));
                    temp.put(i % group,ts);
                }
            }
            for (Set<T> ts : temp.values()) {
                result.add(Lists.newArrayList(ts));
            }
            return result;
        }
    
        // 填充数据
        public static <T> List<T> Augmented(List<T> list ,int size){
            int length = CollectionUtils.isEmpty(list)?0:list.size();
            if (length<1){
                return Lists.newArrayList();
            }
            List<T> result = Lists.newArrayList(list);
            if (length > size){
                return result;
            }
            int count = size - length;
            for (int i = 0; i < count; i++) {
                result.add(list.get(RandomUtils.nextInt(0, length)));
            }
            return result;
        }
    }
    

    Antwort
    0
  • 阿神

    阿神2017-05-17 10:11:17

    1.A.length<=B.length \\对A循环,直接赋值
    
    2.A.length>B.length\\对B循环
    let size = Math.floor(A.length/B.length)\\取整
    for(let i in B){\\数组划分
       if(i==B.lenght-1){
           B[i].item = A.splice(Start)
       }else{
        let start = 0;
        B[i].item = A.splice(start,start + size))
        start = start + 4;
        }
    }

    Antwort
    0
  • StornierenAntwort