今日算法之_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

相关文章

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

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “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. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

usaco 1.2 Name That Number(数字字母转化)

巧妙的利用code[b[0]-'A'] 将字符ABC...Z转换为数字 需要注意的是重新开一个数组 c [ ] 存储字符串 应人为的在末尾附上 ‘ \ 0 ’ 详见代码: /*ID: who jayLANG: C++TASK: namenum*/#include<stdio.h>#include<string.h>int main(){FILE *fin = fopen (

poj 3974 and hdu 3068 最长回文串的O(n)解法(Manacher算法)

求一段字符串中的最长回文串。 因为数据量比较大,用原来的O(n^2)会爆。 小白上的O(n^2)解法代码:TLE啦~ #include<stdio.h>#include<string.h>const int Maxn = 1000000;char s[Maxn];int main(){char e[] = {"END"};while(scanf("%s", s) != EO

hdu 1166 敌兵布阵(树状数组 or 线段树)

题意是求一个线段的和,在线段上可以进行加减的修改。 树状数组的模板题。 代码: #include <stdio.h>#include <string.h>const int maxn = 50000 + 1;int c[maxn];int n;int lowbit(int x){return x & -x;}void add(int x, int num){while