今日算法之_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中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

vue如何监听对象或者数组某个属性的变化详解

《vue如何监听对象或者数组某个属性的变化详解》这篇文章主要给大家介绍了关于vue如何监听对象或者数组某个属性的变化,在Vue.js中可以通过watch监听属性变化并动态修改其他属性的值,watch通... 目录前言用watch监听深度监听使用计算属性watch和计算属性的区别在vue 3中使用watchE

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

从去中心化到智能化:Web3如何与AI共同塑造数字生态

在数字时代的演进中,Web3和人工智能(AI)正成为塑造未来互联网的两大核心力量。Web3的去中心化理念与AI的智能化技术,正相互交织,共同推动数字生态的变革。本文将探讨Web3与AI的融合如何改变数字世界,并展望这一新兴组合如何重塑我们的在线体验。 Web3的去中心化愿景 Web3代表了互联网的第三代发展,它基于去中心化的区块链技术,旨在创建一个开放、透明且用户主导的数字生态。不同于传统

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2241(二分+合并数组)

题意:判断是否存在a+b+c = x,a,b,c分别属于集合A,B,C 如果用暴力会超时,所以这里用到了数组合并,将b,c数组合并成d,d数组存的是b,c数组元素的和,然后对d数组进行二分就可以了 代码如下(附注释): #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<que

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖