0

我有 2 个数组列表,其中记录存储为对象。
第一个 arraylist 对象具有患者 id、totaltestcost、totaltreatmentcost 等属性。第二个 arraylist 对象具有患者 ID、totalservicecharges 等属性。

现在我的问题是当我尝试将总数相加时,即 totaltestcost + totaltreatmentcost + totalservicecharges,对于给定的患者 ID,我无法将总数相加并显示它。

我发现因为它在 2 个数组中,所以我需要按 id 搜索数组并获取成本。

这就是我搜索患者记录的方式 public patient_class searchrecord(ArrayList patients, String search) {

    for(patient_class patient: patients) //used  enhanced for loop


        if(patient.getid().equals(search))
        {

            return patient;
        }
    return null;

}

是否有可能我可以修改此代码以将成本存储在 2 个数组中?

例如像这样:-

公共 int 搜索记录(ArrayList 患者,字符串搜索){

    for(patient_class patient: patients) //used  enhanced for loop


        if(patient.getid().equals(search))
        {

           int total= patient.gettotaltestcost + patient.gettotaltreatmentcost
        }
    return null;

但是如果我使用上述方法只能得到 totaltestcost+totaltreatmentcost 的总和,我还需要获取 servicechargecost 但它在另一个数组中。

那么我该怎么做呢?

感谢您的时间。

编辑 :-

最后我设法做到了伙计们,这就是我的做法:-

public String addtotal(ArrayList patients, String search,ArrayListpatient2,String search2) { int total;

    for(patient_class patient: patients) //used  enhanced for loop

    {
        if(patient.getid().equals(search))
        {



        for(patient_class patient3: patient2)
        {
            if(patient3.getid().equals(search2))
            {
                total=patient.gettreatmentcost()+patient.gettestcost()+patient3.getservicecharge();

                return Double.toString(total);
            }
        }
        }
    }

    return null;

}

我同时传入了两个数组。

感谢大家分享你的答案,下次我肯定会使用树形图

4

3 回答 3

1

我建议更改地图的数据结构。如果您必须使用两个 arrayLists,您可以编写一个方法,将所需的结果作为整数返回。这是低效的。

public static int total(List<Patient> firstList, List<Patient> secondList, int search)
{
    int total = 0;

    for(Patient p:firstList)
    {
        if(p.getId() == search)
        {
            total = p.getServiceCost();
            for(Patient p2 : secondList)
            {
                if(p2.getId()== search)
                {
                    total += p2.gettotaltestcost() + p2.gettotaltreatmentcost();
                    break;
                }
            }
        }
    }
    return total;
}

这是我的想法,没有经过测试,所以你可能会有错误。我假设 id 是一个整数,如果它是一个字符串,您可以将其更改为 .equals。我希望它有所帮助。如果您的类型是 Patient_class,那么当然将所有 Patient 更改为 Patient_class。在你的主要你可以做类似的事情

List<patient_class> list1 = new ArrayList<patient_class>();
List<patient_class> list2 = new ArrayList<patient_class>();
// populate those lists 
int search = 12;    
int result = total(list1, list2, int search);

顺便说一句,只要您指定它们,您就可以将任意数量的列表作为参数传递给方法

public int(ArrayList a, ArrayList b)

不会编译。

于 2013-05-11T13:11:00.003 回答
1

我想你忘记了else关键字。您所有的两种方法都将仅返回null

你需要像这样写一些想法:

public patient_class searchrecord(ArrayList patients, String search) {

for(patient_class patient: patients) //used  enhanced for loop


    if(patient.getid().equals(search))
    {
        return patient;
    }
    else 
        return null;
}

和这个

public int searchrecord(ArrayList patients, String search) {

for(patient_class patient: patients) //used  enhanced for loop


    if(patient.getid().equals(search))
    {
       int total= patient.gettotaltestcost + patient.gettotaltreatmentcost;
       return total;
    }
    else
       return null;
}
于 2013-05-11T12:57:30.537 回答
1

您的代码有很多问题,但是对您的功能进行编码并无视正确的java 编码约定(由于某种原因您显然忽略了这些约定,我不会修复)。我想出了这个。一种在您的列表中查找患者的方法,以及一种从 2 个列表中计算患者总数的方法。

public patient_class findPatient(List<patient_class> patients, String search) {
    for(patient_class patient: patients) //used  enhanced for loop
        if(patient.getid().equals(search))
        {
           return patient;
        }
    }
    return null; // no patient found matching the search id
 }

 public int calculatePatientTotal(List<patient_class> patientsList1, List<patient_class> patientsList2, String search){
    patient_class patientInList1 = findPatient(patientsList1,search);// assuming unique id
    patient_class patientInList2 = findPatient(patientsList2,search);// assuming unique id

    int total=0;
    // calc general total
    if(patientInList1!=null{
        // I'm assuming you put these getters in methods instead of public properties!
        // hence the brackets at the end
        total= patientInList1.gettotaltestcost() + patientInList1.gettotaltreatmentcost();
    } 

    // add any extra charges
    if(patientInList2!=null ){
        // I'm assuming this is the method that calculates the other charges in that patient object.
        total+= patientInList2.getOtherCharges();
    }

    return total;
 }

下次我建议您考虑使用正确的结构,主要是不要将相同的信息分散在不同的项目上。

于 2013-05-11T13:31:45.497 回答