今日算法之_1杀人算法_2数字数组找缺少数字

2024-08-22 21:08

本文主要是介绍今日算法之_1杀人算法_2数字数组找缺少数字,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、杀人算法

解释:把犯人围城一圈,每次杀掉第七个,又从第八个开始杀掉第七个,直到剩下最后一个
代码目录(domo0001KillPerson)
package com.hlj.arith.domo0001KillPerson;import lombok.Data;
import lombok.experimental.Accessors;
import org.junit.jupiter.api.Test;import java.util.ArrayList;
import java.util.List;/*** 1、 杀人算法 :* 把犯人围城一圈,每次杀掉第七个,又从第八个开始杀掉第七个,直到剩下最后一个** @Author HealerJean* @Date 2018/10/10  下午1:37.*/
public class TestMain {@Data@Accessors(chain = true)public class Person {private String name ;private Integer sort;}@Testpublic void start(){Integer n = 20 ;//1、配置人数,名字以及顺序List<Person> persons = setPersonBySystem(n);prinnt(persons);//2、开始杀人,中间使用了递归killPerson(n,persons);}/*** 1、系统输入 人数,设置PerSon的数据* @return*/public List<Person> setPersonBySystem(Integer n){List persons = new ArrayList<>();for(Integer i = 1 ; i<=n ; i++){persons.add(new Person().setName("healerjean"+i).setSort(i));}return  persons ;}/*** 杀人之后重新排序* @param n* @param persons* @return*/public List<Person> killPerson(Integer n, List<Person> persons){List<Person>  personEnd =  persons.subList(7, persons.size()); //从第8为开始取数据List<Person> personStart = persons.subList(0, 6); //从第一位开始取数据personEnd.addAll(personStart);//将前面的加到后面去prinnt(personEnd);if(personEnd.size()>6){ //表示索引最小也得是7killPerson(n, personEnd);}return  personEnd ;}public void prinnt(List<Person> person){person.stream().forEach(s->{System.out.print(s.getSort()+",");});System.out.println();}}

2、给定一个 1-100 的整数数组,请找到其中缺少的数字。

代码目录 (domo0002MissingNumberInArray)
知识点
  • BitSet的应用场景 海量数据去重、排序、压缩存储
  • BitSet的基本操作 and(与)、or(或)、xor(异或)
package com.hlj.arith.domo0002MissingNumberInArray;import org.junit.jupiter.api.Test;import java.util.Arrays;
import java.util.BitSet;/*** @Desc: 给定一个 1-100 的整数数组,请找到其中缺少的数字。** 解答:*  BitSet的应用场景  海量数据去重、排序、压缩存储*  BitSet的基本操作   and(与)、or(或)、xor(异或)*** @Author HealerJean* @Date 2018/10/10  下午2:18.*/
public class TestMain {@Testpublic void start(){// 丢失3个数据printMissingNumber(new int[]{1, 2, 3, 4, 6, 9, 8}, 10);// Only one missing number in arrayint[] iArray = new int[]{1, 2, 3, 5};int missing = getMissingNumber(iArray, 5);}/*** BitSet   海量数据去重、排序、压缩存储* @param numbers* @param count*/private  void printMissingNumber(int[] numbers, int count) {int missingCount = count - numbers.length;BitSet bitSet = new BitSet(count);for (int number : numbers) {bitSet.set(number - 1); //数据是从1开头的,这里是获取下标索引}System.out.println("一共有"+count+"个数据:目前数组为"+Arrays.toString(numbers));int lastMissingIndex = 0;for (int i = 0; i < missingCount; i++) {lastMissingIndex = bitSet.nextClearBit(lastMissingIndex);//返回下个清零位的索引,(即,下一个零位),从由startIndex指定的索引开始System.out.println(++lastMissingIndex);}}/*** 如果是数组中之缺少一个,则根据1到100的累加和 减去 目前的数组的累加和* @param numbers* @param totalCount* @return*/private  int getMissingNumber(int[] numbers, int totalCount) {int expectedSum = totalCount * ((totalCount + 1) / 2);int actualSum = 0;for (int i : numbers) {actualSum += i;}System.out.println("一共有"+totalCount+"个数据:目前数组为"+Arrays.toString(numbers));System.out.println(expectedSum - actualSum);return expectedSum - actualSum;}}

ContactAuthor

这篇关于今日算法之_1杀人算法_2数字数组找缺少数字的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097402

相关文章

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

Python实现特殊字符判断并去掉非字母和数字的特殊字符

《Python实现特殊字符判断并去掉非字母和数字的特殊字符》在Python中,可以通过多种方法来判断字符串中是否包含非字母、数字的特殊字符,并将这些特殊字符去掉,本文为大家整理了一些常用的,希望对大家... 目录1. 使用正则表达式判断字符串中是否包含特殊字符去掉字符串中的特殊字符2. 使用 str.isa

Java数组初始化的五种方式

《Java数组初始化的五种方式》数组是Java中最基础且常用的数据结构之一,其初始化方式多样且各具特点,本文详细讲解Java数组初始化的五种方式,分析其适用场景、优劣势对比及注意事项,帮助避免常见陷阱... 目录1. 静态初始化:简洁但固定代码示例核心特点适用场景注意事项2. 动态初始化:灵活但需手动管理代