| | |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | |
| | | import java.math.BigDecimal; |
| | | import java.util.HashMap; |
| | | import java.util.List; |
| | | import java.util.Map; |
| | | import java.util.Set; |
| | | import java.util.*; |
| | | import java.util.stream.Collectors; |
| | | |
| | | /** |
| | |
| | | return member; |
| | | } |
| | | |
| | | public static void main(String[] args) { |
| | | String inputString = |
| | | // "36707681,36605256,36506391,36402334," + |
| | | // "36303396,36103193,35801871,34603197," + |
| | | // "33502855,26309863,99073916,98024982," + |
| | | // "97059583,95058331,92037722,91048635," + |
| | | "89019478,88021442,84073227,20441682"; |
| | | String target = "91048635"; |
| | | |
| | | // 调用函数进行匹配并输出结果 |
| | | if (shouldOutputString(inputString, target)) { |
| | | System.out.println(inputString); |
| | | } else { |
| | | System.out.println("No match found within the last 8 substrings."); |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * 检查输入字符串从后往前匹配目标字符串的位置是否小于8(基于逗号分隔的子串数量) |
| | | * |
| | | * @param inputString 输入的字符串 |
| | | * @param target 目标字符串 |
| | | * @return 如果匹配的位置小于8,则返回true;否则返回false |
| | | */ |
| | | public static boolean shouldOutputString(String inputString, String target) { |
| | | // 按逗号分隔字符串 |
| | | String[] substrings = inputString.split(","); |
| | | |
| | | // 从后往前遍历子串数组 |
| | | for (int i = substrings.length - 1; i >= 0; i--) { |
| | | // 去掉子串两侧的空白字符(如果有的话) |
| | | String trimmedSubstring = substrings[i].trim(); |
| | | System.out.println(trimmedSubstring); |
| | | |
| | | // 检查子串是否与目标字符串匹配 |
| | | if (trimmedSubstring.equals(target)) { |
| | | // 如果匹配且位置小于8(基于0索引,所以实际上是倒数第9个或更前的位置) |
| | | if (substrings.length - i < 8) { |
| | | return true; // 输出整个原始字符串 |
| | | } |
| | | break; // 匹配但位置不在要求范围内,退出循环 |
| | | } |
| | | } |
| | | |
| | | return false; // 没有找到匹配项或匹配项位置不符合要求 |
| | | } |
| | | |
| | | @Override |
| | | public TeamListVo findTeamList() { |
| | | TeamListVo teamListVo = new TeamListVo(); |
| | |
| | | teamListVo.setAvaAmount(BigDecimal.ZERO); |
| | | } |
| | | |
| | | ArrayList<DappMemberEntity> objects = new ArrayList<>(); |
| | | //八层团队业绩 |
| | | if(CollUtil.isNotEmpty(dappMemberEntities)){ |
| | | for(DappMemberEntity memberEntity : dappMemberEntities){ |
| | | String refererIds = memberEntity.getRefererIds(); |
| | | if (shouldOutputString(refererIds, member.getInviteId())) { |
| | | objects.add(memberEntity); |
| | | } |
| | | } |
| | | List<Long> collect = objects.stream().map(DappMemberEntity::getId).collect(Collectors.toList()); |
| | | QueryWrapper<DappAchieve> queryWrapper = new QueryWrapper<>(); |
| | | queryWrapper.in("member_id",collect); |
| | | List<DappAchieve> dappAchieveSumList = dappAchieveMapper.selectList(queryWrapper); |
| | | |
| | | List<DappAchieve> filteredList = dappAchieveSumList.stream() |
| | | .filter(obj -> obj.getState() == 1) |
| | | .collect(Collectors.toList()); |
| | | BigDecimal perkAmount = filteredList.stream().map(DappAchieve::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add); |
| | | teamListVo.setPerkAmount(perkAmount); |
| | | |
| | | }else{ |
| | | teamListVo.setPerkAmount(BigDecimal.ZERO); |
| | | } |
| | | |
| | | |
| | | List<DappMemberEntity> dappMemberEntitiesAva = dappMemberDao.selectChildMemberDirectOrNot(member.getInviteId(), 1); |
| | | if(CollUtil.isNotEmpty(dappMemberEntitiesAva)){ |