如何将适当的成本应用于排名选择

问题描述 投票:1回答:2

我列出了4个活动选项

Activities
Activity 1
Activity 2
Activity 3
Activity 4

我列出了一系列人员,他们选择了按顺序排列的4项活动,例如

Person    Choices (1st,2nd,3rd,4th)
Person 1  2,3,1,4
Person 2  3,1,4,2
...

我试图根据他们的位置为排名选择分配成本,并且只是想知道我是如何做到的。一个例子是人1,其第一选择是活动2,其成本是1.他们的第二选择是活动3,成本是2,因为它在位置2,依此类推。我将这些成本添加到列表中,因为我稍后需要以相同的顺序列出此成本列表。

代码我试过了

List<Integer> cost = new ArrayList<Integer>();
for(Person p: people){
 for (int i = 0; i < p.getChoices().size(); i++) {

  cost.add(p.getChoices(i+1);
 }
}

只是一些额外的上下文然后,成本列表将用于填充运输问题网格,其中源由活动表示,如下所示。网格中的来源处于固定位置,所以当看人时1.活动2是他们的第一选择,活动3是他们的第2,活动1是他们的第3,活动4是他们的第4。

  Person 1 | Person2 | Person n
1     3         2
2     1         4
3     2         1
4     4         3

我一直很困惑如何应用它,因为它应该很简单。在我以前的实现中,我最终只得到1,2,3,4的成本列表。由于某种原因,我无法理解这个理论(因为早上5点XD)。我对任何理论或伪代码持开放态度。先感谢您!

java arraylist ranking
2个回答
0
投票

如果某人的活动成本是其在选择中的位置,您可以在类Person中声明方法costOf

public class Person {
    private final List<Integer> choices = new ArrayList<>();

    public Person(Integer... choices) {
        this.choices.addAll(Arrays.asList(choices));
    }

    public List<Integer> getChoices() {
       return choices;
    }

    public int costOf(Integer activity) {
        return choices.indexOf(activity)+1;
    }
}

要打印网格,您可以这样做:

    List<Person> persons = Arrays.asList(
                new Person(2,3,1,4),
                new Person(3,1,4,1)
            );
    // Print grid
    for (int activity = 1; activity <= 4; ++activity) {
        System.out.print(activity);
        for (Person p: persons) {
            System.out.print(" ");
            System.out.print(p.costOf(activity));
        }
        System.out.println();
    }

这将打印:

1 3 2
2 1 0
3 2 1
4 4 3

您可以看到存在零,因为第二个人的选择中没有2。

假设它是一个拼写错误,你用2替换第二个1,你会得到:

1 3 2
2 1 4
3 2 1
4 4 3

什么是预期的。


0
投票

我正在写一个示例代码。根据我对你的问题的理解,我已经为你编写了一个代码。

人类

import java.util.ArrayList;

public class Person {
    ArrayList<Integer> choices = new ArrayList<>();

    public ArrayList<Integer> getChoices() {
       return choices;
    }

    public void setChoices(ArrayList<Integer> choices) {
       this.choices = choices;
    }
}

主要方法

public class MainMethod {

    public static void main(String[] args) {

       Person person1 = new Person();
       ArrayList<Integer> activity1 = new ArrayList<>();
       activity1.add(2);
       activity1.add(3);
       activity1.add(1);
       activity1.add(4);
       person1.setChoices(activity1);

       Person person2 = new Person();
       ArrayList<Integer> activity2 = new ArrayList<>();
       activity2.add(2);
       activity2.add(4);
       activity2.add(1);
       activity2.add(3);
       person2.setChoices(activity2);

       Person person3 = new Person();
       ArrayList<Integer> activity3 = new ArrayList<>();
       activity3.add(1);
       activity3.add(3);
       activity3.add(4);
       activity3.add(2);
       person3.setChoices(activity3);

       Person person4 = new Person();
       ArrayList<Integer> activity4 = new ArrayList<>();
       activity4.add(4);
       activity4.add(3);
       activity4.add(1);
       activity4.add(4);
       person4.setChoices(activity4);

       ArrayList<Person> persons = new ArrayList<>();
       persons.add(person1);
       persons.add(person2);
       persons.add(person3);
       persons.add(person4);

       int i = 1;
       for(Person person :persons) {
           System.out.println("Person"+i);
           //List
           person.getChoices().forEach(System.out::println);
           i++;
       }
       System.out.println("**********************");
       //If you need cost list. I gave you option to store in list as well.
       int j = 1;
       for(Person person :persons) {
        System.out.println("Person"+j);
        ArrayList<Integer> cost = person.getChoices();
        cost.stream().forEach(System.out::println);
        i++;
       }
   }
}

如果您的要求不同,请详细说明并告诉我。

© www.soinside.com 2019 - 2024. All rights reserved.