我在做一个Web请假(图表操作形式)老师通过点击表格列选中,表示这个时间请假。当老师在一周的表格上点了很多下的时候,Jquery通过样式查找得到老师选中的时间片ID,形如 (1_1,1_2,1_3,3_3,3_4,3_5)这样一个字符串。这个形式表示老师星期一,1,2,3节课请假,星期三,3,4,5节课请假。因为我在数据里要插入2条记录。所以要把(1_1,1_2,1_3,3_3,3_4,3_5)分割成(1_1,1_2)(3_3,3_4,3_5)这2个字符串。请问有什么好的算法没有?我的想法:1.分割成数组all[]遍历,把_前的数字找出来。去掉重复,放到一个临时数组 pre[].2.创建数组temp[pre.length]。再双重遍历all[]与pre[],遍历的时候if(all[i].startWith(pre[j]))temp[j]+=all[i]+","3.最后得到的temp[]就是要的结果?总感觉有点麻烦。求更好的算法.
2 回答
肥皂起泡泡
TA贡献1829条经验 获得超6个赞
1.你如果能保证1_X在3_X前面,就声明一个变量,保存截取的第一个字符,如果当前截取的和之前的不一样就说明已经循环到了下一个时间段。这样就能获得你要的结果。
2.如果不能保证,就把截取的第一个字符放到Map中,key就是你的第一个字符,value就是拼接的字符,每次先拿截取的第一个字符串查询Map中的值,有就拼接,没有就添加一个。
一只萌萌小番薯
TA贡献1795条经验 获得超7个赞
字符串1_1,1_2,1_3,3_3,3_4,3_5分隔为数组,将数据类型为M_N的数据用map来保存,针对你所提出的例子,最终map数据为key:1,value:1,2,3;key:3,value:3,4,5
添加回答
举报
0/150
提交
取消