闲人のMr丶Wu 2012-04-21 12:54
浏览 357
已采纳

判断上一行数据,并计算平均值

数据如下:
零件代号 col1 col2 col3
A 11 12 10
B 22 20 13

现在遇到这样一个问题,根据零件代号判断当前行的零件代号是否与上一行的零件代号相同,如果相同则计算3*2列数据的平均值,如上述列表数据,如果第二行的零件代号B是A的话,则平均值=(11+12+10+22+20+13)/6,否则分别计算出各行数据的平均值,很郁闷不知道用java循环如何实现了,知道的同学帮忙解答一下,非常感谢!
补:这里的记录行数有很多,只需要与上一行相比即可。

  • 写回答

7条回答 默认 最新

  • zyn010101 2012-04-21 18:26
    关注

    List list = 查询数组;
    List finalList = new ArrayList ();
    for(int i=0;i<list.size();i++){

    if(i==0){
    Object[] o = list.get(i);
    float avg = (Integer.valueof(o[1].toSring())+Integer.valueof(o[2].toSring())+Integer.valueof(o[3].toSring()))/3;
    Object[] ob = new Object[5];
    ob[0] = o[0];
    ob[1] = o[1];
    ob[2] = o[2];
    ob[3] = o[3];
    ob[4] = avg;
    }else{
    Object[] o = list.get(i);
    Object[] o1 = list.get(i-1);
    float avg = 0;
    if(o[0].toSring().equals(o1[0].toSring())){
    avg= (Integer.valueof(o[1].toSring())+Integer.valueof(o[2].toSring())+Integer.valueof(o[3].toSring())+Integer.valueof(o1[1].toSring())+Integer.valueof(o1[2].toSring())+Integer.valueof(o1[3].toSring()))/6;

     }else{
       avg = (Integer.valueof(o[1].toSring())+Integer.valueof(o[2].toSring())+Integer.valueof(o[3].toSring()))/3;
    
    }
    Object[] ob = new Object[5];
     ob[0] = o[0];
     ob[1] = o[1];
     ob[2] = o[2];
     ob[3] = o[3];
     ob[4] = avg;
     finalList.add(ob);
    

    }
    }

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(6条)

报告相同问题?

悬赏问题

  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)
  • ¥20 matlab yalmip kkt 双层优化问题
  • ¥15 如何在3D高斯飞溅的渲染的场景中获得一个可控的旋转物体