<蓝桥杯软件赛>零基础备赛20周--第16周--GCD和LCM

报名明年4月蓝桥杯软件赛的同学们,如果你是大一零基础,目前懵懂中,不知该怎么办,可以看看本博客系列:备赛20周合集
20周的完整安排请点击:20周计划
每周发1个博客,共20周。
在QQ群上交流答疑:

在这里插入图片描述

文章目录

  • 1. GCD
    • 1.1 GCD概念
    • 1.2 GCD性质
    • 1.2 GCD编码实现
  • 2. LCM
  • 3. 例题
    • 3.1 等差数列
    • 3.2 Hankson的趣味题
    • 3.3 最大比例

第16周:GCD和LCM
  最大公约数(GCD)和最小公倍数(Least Common Multiple,LCM)研究整除的性质,非常古老,2000多年前就得到了很好的研究。由于简单易懂,有较广泛的应用,是竞赛中频繁出现的考点。
最大公约数有多种英文表述:Greatest Common Divisor(GCD)、Greatest Common Denominator、Greatest Common Factor(GCF)、Highest Common Factor (HCF)。

1. GCD

1.1 GCD概念

   整数a和b的最大公约数是能同时整除a和b的最大整数,记为gcd(a, b)。
  负整数也可以算gcd,不过由于-a的因子和a的因子相同,编码时只需要关注正整数的最大公约数。下面用c++函数std::__gcd(a, b)演示gcd的计算结果。

#include<bits/stdc++.h>
using namespace std;
int main(){
    cout << __gcd(45,9)   <<"\n";   // 9
    cout << __gcd(0,42)   <<"\n";   // 42
    cout << __gcd(42,0)   <<"\n";   // 42
    cout << __gcd(0,0)    <<"\n";   // 0
    cout << __gcd(20,15)  <<"\n";   // 5
    cout << __gcd(-20,15) <<"\n";   // -5
    cout << __gcd(20,-15) <<"\n";   // 5
    cout << __gcd(-20,-15)<<"\n";   // -5
    cout << __gcd((long long)98938441343232,(long long)33422)<<"\n"; //2
}

  Java没有自带GCD库函数。
  Python自带的GCD函数,只返回正整数。

from  math import *
print(gcd(45, 9))                # 9
print(gcd(0, 42))                # 42
print(gcd(42, 0))                # 42
print(gcd(0, 0))                 # 0
print(gcd(20, 15))               # 5
print(gcd(-20, 15))              # 5
print(gcd(20, -15))              # 5
print(gcd(-20, -15))             # 5
print(gcd(98938441343232, 33422)) # 2

1.2 GCD性质

  GCD有关的题目一般会考核GCD的性质。
  (1)gcd(a, b) = gcd(a, a+b) = gcd(a, k·a+b)
  (2)gcd(ka, kb) = k·gcd(a, b)
  (3)多个整数的最大公约数:gcd(a, b, c) = gcd(gcd(a, b), c)。
  (4)若gcd(a, b) = d,则gcd(a/d, b/d) = 1,即a/d与b/d互素。这个定理很重要。
  (5)gcd(a+cb, b) = gcd(a, b)

1.2 GCD编码实现

   编程时可以不用自己写GCD代码,而是直接使用c++函数std::__gcd(a, b)。如果自己编码也很简单,用欧几里得算法,又称为辗转相除法,即gcd(a, b) = gcd(b, a mod b)。

int gcd(int a, int b){        // 一般要求a>=0, b>0。若a=b=0,代码也正确,返回0
	return b? gcd(b, a%b):a;
}

  Java的gcd需要自己写。

import java.math.BigInteger;
public class Main {
    public static void main(String[] args) {
        System.out.println(gcd(45, 9));                // 9
        System.out.println(gcd(0, 42));                // 42
        System.out.println(gcd(42, 0));                // 42
        System.out.println(gcd(0, 0));                 // 0
        System.out.println(gcd(20, 15));               // 5
        System.out.println(gcd(-20, 15));              // -5
        System.out.println(gcd(20, -15));              // 5
        System.out.println(gcd(-20, -15));             // -5
        System.out.println(gcd(new BigInteger("98938441343232"), new BigInteger("33422"))); // 2
    }
    public static long gcd(long a, long b) {
        if (b == 0)   return a;        
        return gcd(b, a % b);
    }
    public static BigInteger gcd(BigInteger a, BigInteger b) {
        return a.gcd(b);
    }
}

  python。自己写gcd()函数,可能返回负数。

def gcd(a,b):
    if b ==0:return a
    else: return gcd(b,a%b)
print(gcd(45, 9))                # 9
print(gcd(0, 42))                # 42
print(gcd(42, 0))                # 42
print(gcd(0, 0))                 # 0
print(gcd(20, 15))               # 5
print(gcd(-20, 15))              # 5
print(gcd(20, -15))              # -5
print(gcd(-20, -15))             # -5
print(gcd(98938441343232, 33422)) # 2

2. LCM

   最小公倍数LCM(the Least Common Multiple)。a和b的最小公倍数lcm(a, b),从算术基本定理推理得到。
  算术基本定理:任何大于1的正整数n都可以唯一分解为有限个素数的乘积: n = p 1 c 1 p 2 c 2 . . . p m c m n = p_1^{c1}p_2^{c2}...p_m^{cm} n=p1c1p2c2...pmcm,其中ci都是正整数, p i p_i pi都是素数且从小到大。
  设: a = p 1 c 1 p 2 c 2 . . . p m c m , b = p 1 f 1 p 2 f 2 . . . p m f m a = p_1^{c1}p_2^{c2}...p_m^{cm},b = p_1^{f1}p_2^{f2}...p_m^{fm} a=p1c1p2c2...pmcmb=p1f1p2f2...pmfm
  那么:
     g c d ( a , b ) = p 1 m i n { c 1 , f 1 } p 2 m i n { c 2 , f 2 } . . . p m m i n { c m , f m } gcd(a, b) = p_1^{min\{c1,f1\}}p_2^{min\{c2,f2\}}...p_m^{min\{cm,fm\}} gcd(a,b)=p1min{c1,f1}p2min{c2,f2}...pmmin{cm,fm}
     l c m ( a , b ) = p 1 m a x { c 1 , f 1 } p 2 m a x { c 2 , f 2 } . . . p m m a x { c m , f m } lcm(a, b) = p_1^{max\{c1,f1\}}p_2^{max\{c2,f2\}}...p_m^{max\{cm,fm\}} lcm(a,b)=p1max{c1,f1}p2max{c2,f2}...pmmax{cm,fm}
  可以推出:
     g c d ( a , b ) ∗ l c m ( a , b ) = a ∗ b gcd(a, b)*lcm(a, b) = a*b gcd(a,b)lcm(a,b)=ab
  即
     l c m ( a , b ) = a ∗ b / g c d ( a , b ) = a / g c d ( a , b ) ∗ b lcm(a, b) = a*b/gcd(a, b) = a/gcd(a, b)*b lcm(a,b)=ab/gcd(a,b)=a/gcd(a,b)b

c++代码

int lcm(int a, int b){          //需要的时候把int改成long long
	return a / gcd(a, b) * b;  //先做除法再做乘法,防止先做乘法溢出
}

java代码

    public static int gcd(int a, int b) {
        if (b == 0)        return a;        
        return gcd(b, a % b);
    }
    public static long lcm(int a, int b) {
        return (long) a / gcd(a, b) * b;
    }

python代码
  在Python新版本中有库函数lcm(),它可以带多个参数。

from  math import *
print(lcm(3,6,8,9))  #输出72

  也可以自己写一个:

from  math import *
def lcm(x,y):   return x//gcd(x,y)*y

3. 例题

  GCD和LCM的题目太多了,随便到哪个OJ都能以GCD为算法关键词搜出很多。

3.1 等差数列


等差数列
【题目描述】数学老师给小明出了一道等差数列求和的题目。但是粗心的小明忘记了一部分的数列,只记得其中N个整数。现在给出这N个整数,小明想知道包含这N个整数的最短的等差数列有几项?
【输入描述】输入的第一行包含一个整数N。 第二行包含N个整数A1,A2,···,AN。(注意A1 ∼AN并不一定是按等差数列中的顺序给出) (对于所有评测用例,2≤N≤100000,0≤Ai≤ 1 0 9 10^9 109。)
【输出描述】输出一个整数表示答案


  所有数字间距离最小的间隔是公差吗? 并不是,例如{2,5,7},最小的间隔是2,但公差不是2,是1。
  这是gcd问题。把n个数据排序,计算它们的间隔,对所有间隔做GCD,结果为公差。最少数量等于:(最大值-最小值)/公差+1。
c++代码

#include<bits/stdc++.h>
using namespace std;
int a[100000];
int main(){
    int n;   cin>>n;
    for(int i=0;i<n;i++)   cin>>a[i];
    sort(a,a+n);
    int d=0;
    for(int i=1;i<n;i++)   d = __gcd(d,a[i]-a[i-1]);     
    if(d==0) cout<<n<<endl;
    else     printf("%d\n",(a[n - 1] - a[0]) / d + 1);
    return 0;
}

Java代码

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int[] a = new int[n];
        for (int i = 0; i < n; i++)  a[i] = sc.nextInt(); 
        Arrays.sort(a);
        int d = 0;
        for (int i = 1; i < n; i++)  d = gcd(d, a[i] - a[i - 1]);        
        if (d == 0)    System.out.println(n);
        else     System.out.println((a[n - 1] - a[0]) / d + 1);        
    }

    public static int gcd(int a, int b) {
        if (b == 0)  return a;        
        return gcd(b, a % b);
    }
}

python代码

from  math import *
n=int(input())
a=list(map(int,input().split()))
a.sort()
d=0
for i in range(1,n):  d=gcd(d,a[i]-a[i-1])
if d==0:  print(n)
else:     print((a[-1]-a[0])//d+1)

3.2 Hankson的趣味题


Hankson的趣味题
【题目描述】刚刚放学回家的Hankson正在思考一个有趣的问题。今天在课堂上,老师讲解了如何求两个正整数c1和c2的最大公约数和最小公倍数。现在Hankson认为自己已经熟练地掌握了这些知识,他开始思考一个“求公约数”和“求公倍数”之类问题的“逆问题”,这个问题是这样的:已知正整数a0,a1,b0,b1,设某未知正整数x满足:

  1. x和a0 的最大公约数是a1;
  2. x和b0的最小公倍数是b1。
    Hankson的“逆问题”就是求出满足条件的正整数x。但稍加思索之后,他发现这样的x并不唯一,甚至可能不存在。因此他转而开始考虑如何求解满足条件的x的个数。请你帮助他编程求解这个问题。
    【输入格式】输入第一行为一个正整数n,表示有n组输入数据。 接下来的n行每行一组输入数据,为四个正整数a0,a1,b0,b1,每两个整数之间用一个空格隔开。输入数据保证a0能被a1整除,b1能被b0整除。
    数据规模:对于100%的数据,保证有1≤a0,a1,b0,b1≤2,000,000,000且n≤2000。
    【输出格式】输出共n行。每组输入数据的输出结果占一行,为一个整数。对于每组数据:若不存在这样的x,请输出0;若存在这样的x,请输出满足条件的x的个数。

  最简单的暴力法,是把所有可能的x试一遍。x的范围是x ≤ b1。
  但是,由于本题的数据范围是 b 1 ≤ 2 × 1 0 9 b1 ≤ 2×10^9 b12×109,肯定超时。
  若x是b1的因子,那么x*y = b1,y也可能是答案。所以只需要在范围x<=sqrt(b1)内查询,同时判断y就行了。
  但是这样还是超时,因为gcd计算也要花时间,最后加上一个优化:if(b1%x==0),表示b1是x的公倍数。

c++代码

#include<bits/stdc++.h>
using namespace std;
int lcm(int a, int b){ return a / __gcd(a, b) * b;}
int main() {
    int n; scanf("%d",&n);
    while(n--) {
        int a0,a1,b0,b1;
        cin >>a0>>a1>>b0>>b1;
        int ans=0;
        for(int x=1;x <= sqrt(b1);x++){
            if(b1%x == 0){        //优化
                if(__gcd(x,a0)==a1 && lcm(x,b0)==b1)  ans++;
                int y = b1/x;       //另外一个因子
                if(x==y) continue;
                if(__gcd(y,a0)==a1 && lcm(y,b0)==b1)  ans++;
            }
        }
        cout << ans <<endl;
    }
    return 0;
}

java

import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        while (n-- > 0) {
            int a0 = sc.nextInt();
            int a1 = sc.nextInt();
            int b0 = sc.nextInt();
            int b1 = sc.nextInt();
            int ans = 0;
            for (int x = 1; x <= Math.sqrt(b1); x++) {
                if (b1 % x == 0) {
                    if (gcd(x, a0) == a1 && lcm(x, b0) == b1)   ans++;                    
                    int y = b1 / x;
                    if (x == y) continue;                    
                    if (gcd(y, a0) == a1 && lcm(y, b0) == b1)    ans++;                    
                }
            }
            System.out.println(ans);
        }
    }
    public static int gcd(int a, int b) {
        if (b == 0) return a;        
        return gcd(b, a % b);
    }

    public static int lcm(int a, int b) {
        return a / gcd(a, b) * b;
    }
}

python

from  math import *
def lcm(x,y):  return x//gcd(x,y)*y
n=int(input())
for _ in range(n):
    a0,a1,b0,b1 = map(int,input().split())
    ans=0
    for x in range(1,int(sqrt(b1))+1):
        if b1 % x == 0:
            if gcd(x,a0)==a1 and lcm(x,b0)==b1: ans+=1
            y = b1//x
            if x==y: continue
            if gcd(y,a0)==a1 and lcm(y,b0)==b1: ans+=1
    print(ans)

3.3 最大比例


最大比例
【题目描述】X星球的某个大奖赛设了M级奖励。每个级别的奖金是一个正整数。并且,相邻的两个级别间的比例是个固定值。也就是说:所有级别的奖金数构成了一个等比数列。比如:16,24,36,54
其等比值为:3/2
现在,我们随机调查了一些获奖者的奖金数。请你据此推算可能的最大的等比值。
【输入格式】第一行为数字 N (0<N<100),表示接下的一行包含N个正整数。第二行N个正整数Xi(Xi<1 000 000 000 000),用空格分开。每个整数表示调查到的某人的奖金数额。
【输出格式】一个形如A/B的分数,要求A、B互质。表示可能的最大比例系数。
测试数据保证了输入格式正确,并且最大比例是存在的。


  先试试暴力法。
  把这些数字排个序,然后算出相邻两个数的比值。最小的那个比值K是否就是答案呢?
  不是。例如{2, 16, 64},比值是16/2=8,64/16=4,最小比值K=4。但是原序列是{2, 4, 8, 16, 32, 64},比值是2。
  所以答案肯定比K小,如何求出答案?如果一个个试比K小的分数,肯定会超时。
  再用另一个思路,这次不是算相邻两个数的比值,而是每个数对第一个数的比值,会不会好些?
  设原序列是 x , x q 1 , x q 2 , . . . , x q n − 1 {x, xq^1, xq^2, ..., xq^{n-1}} x,xq1,xq2,...,xqn1,从中挑出一些数字 x q c , x q d , . . . , x q y , x q z {xq^c, xq^d, ..., xq^y, xq^z} xqc,xqd,...,xqy,xqz,它们之间的两两相除,得到一个比值序列 1 , q d − c , . . . , q z − y {1, q^{d-c}, ... , q^{z-y}} 1,qdc,...,qzy,这其中的一些数字可能是相同的,有点麻烦。
  或者算它们对第一个数的比值,得 1 , q d − c , . . . , q y − c , q z − c = 1 , q k d , . . . , q k y , q k z {1, q^{d-c}, ... , q^{y-c} , q^{z-c}} ={1, q^{kd}, ... , q^{ky} , q^{kz}} 1,qdc,...,qyc,qzc=1,qkd,...,qky,qkz ,这个序列内的所有数字肯定不同。令 q = a / b q = a/b q=a/b,那么这个序列变成了 1 , ( a / b ) k d , . . . , ( a / b ) k y , ( a / b ) k z {1, (a/b)^{kd}, ..., (a/b)^{ky}, (a/b)^{kz}} 1,(a/b)kd,...,(a/b)ky,(a/b)kz。分成分子和分母两个序列,分别是 A = a k d , . . . , a k y , a k z , B = b k d , . . . , b k y , b k z A={a^{kd}, ..., a^{ky}, a^{kz}}, B={b^{kd}, ..., b^{ky}, b^{kz}} A=akd,...,aky,akz,B=bkd,...,bky,bkz
  已知这两个序列A、B中每个元素的值,求a和b。
  例如A={16, 128, 512, 1024},得a=2,即 A = 2 4 , 2 7 , 2 9 , 2 10 A={2^4, 2^7, 2^9, 2^{10}} A=24,27,29,210。如何根据A求a?
  显然,A中每个数除以前面一个数,都能够整除,得到a的一个倍数,但是这个倍数还不是a,需要继续除,直到得到a为止。以前2个数 2 4 , 2 7 {2^4, 2^7} 24,27为例,计算步骤是: 2 7 / 2 4 = 2 3 , 2 4 / 2 3 = 2 1 , 2 3 / 2 1 = 2 2 , 2 2 / 2 1 = 2 , 2 1 / 2 1 = 1 2^7/2^4=2^3,2^4/2^3=2^1,2^3/2^1=2^2,2^2/2^1=2,2^1/2^1=1 27/24=2324/23=2123/21=2222/21=221/21=1,结束,得a=2。这是一个辗转相除的过程。
  对A中所有元素都执行这个过程,就得到了a。下面代码中的gcd_sub()完成了这一任务。

c++代码

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 105;
ll x[N],a[N],b[N];
ll gcd_sub(ll a,ll b){
    if(a<b)   swap(a,b);
    if(b==1)  return a;
    return gcd_sub(b,a/b);
}
int main(){
    int n; cin >>n;
    ll cnt=0;
    for(int i=0;i<n;i++)  cin>>x[i];
    sort(x,x+n);         //排序
    for(int i=1;i<n;i++){
        ll d = __gcd(x[i],x[0]);
        a[cnt] = x[i]/d;
        b[cnt] = x[0]/d;   //约分,得分子a / 分母b
        cnt++;
    }
    ll up = a[0], down = b[0];
    for(int i=1;i<cnt;i++){
        up= gcd_sub(up,a[i]);        //求分子
        down = gcd_sub(down,b[i]);   //求分母
    }
    cout<<up<<'/'<<down<<endl;
    return 0;
}

java

import java.util.Arrays;
import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        long[] x = new long[n];
        for (int i = 0; i < n; i++)   x[i] = sc.nextLong();        
        Arrays.sort(x);
        long[] a = new long[n - 1];
        long[] b = new long[n - 1];
        int cnt = 0;
        for (int i = 1; i < n; i++) {
            long d = gcd(x[i], x[0]);
            a[cnt] = x[i] / d;
            b[cnt] = x[0] / d;
            cnt++;
        }
        long up = a[0];
        long down = b[0];
        for (int i = 1; i < cnt; i++) {
            up = gcdSub(up, a[i]);
            down = gcdSub(down, b[i]);
        }
        System.out.println(up + "/" + down);
    }

    public static long gcd(long a, long b) {
        if (b == 0) return a;        
        return gcd(b, a % b);
    }

    public static long gcdSub(long a, long b) {
        if (a < b) {long temp = a; a = b; b = temp; }
        if(b==1) return a;
        return gcdSub(b,a/b);
    }
}

python

from math import *
def gcd_sub(a,b):
    if a<b: a,b = b,a
    if b==1: return a
    return gcd_sub(b,a//b);
n = int(input())
x = list(set(map(int,input().split())))  #set有去重的作用
x.sort()
n = len(x)
a=[]
b=[]
for i in range(1,n):
    d = gcd(x[i],x[0])
    a.append(x[i]//d)
    b.append(x[0]//d)
n = len(a)
up = a[0]
down = b[0]
for i in range(1,n):
    up = gcd_sub(up,a[i])
    down = gcd_sub(down,b[i])
print('%d/%d'%(up,down))

  其他练习,请到这里:洛谷的GCD题目

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/344367.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

acwing 动态规划dp 0 1背包问题

前言 hello小伙伴们&#xff0c;最近由于个人放假原因颓废了一段时间很长时间没有更新CSDN的内容了&#xff0c;唉&#xff0c;毕竟懂得都懂寒暑假静下心来学习的难度远比在学校里大的多。 但是&#xff0c;也不是毫无办法克服&#xff0c;今天我来了我们当地的一家自习室来学习…

大数据开发之Spark(RDD弹性分布式数据集)

第 1 章&#xff1a;rdd概述 1.1 什么是rdd rdd&#xff08;resilient distributed dataset&#xff09;叫做弹性分布式数据集&#xff0c;是spark中最基本的数据抽象。 代码中是一个抽象类&#xff0c;它代表一个弹性的、不可变、可分区、里面的元素可并行计算的集合。 1.1…

【操作工具】IDEA的properties文件变为灰色的解决办法

背景 赋值了一份properties文件放到项目下面&#xff0c;但是里面的key都是灰色的 解决方案 去掉下面3后面对应的勾 去掉之后

Java零基础学习18:字符串

编写博客目的&#xff1a;本系列博客均根据B站黑马程序员系列视频学习和编写目的在于记录自己的学习点滴&#xff0c;方便后续回忆和查找相关知识点&#xff0c;不足之处恳请各位有缘的朋友指正。 一、字符串拼接 第一题&#xff1a;false 第二题&#xff1a;true 二、 字符串…

Java项目:12 Springboot的垃圾回收管理系统

作者主页&#xff1a;舒克日记 简介&#xff1a;Java领域优质创作者、Java项目、学习资料、技术互助 文中获取源码 1.介绍 垃圾分类查询管理系统&#xff0c;对不懂的垃圾进行查询进行分类并可以预约上门回收垃圾。 让用户自己分类垃圾&#xff0c; 按国家标准自己分类&#x…

LabVIEW高级CAN通信系统

LabVIEW高级CAN通信系统 在现代卫星通信和数据处理领域&#xff0c;精确的数据管理和控制系统是至关重要的。设计了一个基于LabVIEW的CAN通信系统&#xff0c;它结合了FPGA技术和LabVIEW软件&#xff0c;主要应用于模拟卫星平台的数据交换。这个系统的设计不仅充分体现了FPGA在…

CSS实现文本和图片无限滚动动画

Demo图如下&#xff1a; <style>* {margin: 0;padding: 0;box-sizing: border-box;font-family: Poppins, sans-serif;}body {min-height: 100vh;background-color: rgb(11, 11, 11);color: #fff;display: flex;flex-direction: column;justify-content: center;align-i…

2024 年值得收藏的 6 大 iPad 恢复软件

众所周知&#xff0c;数据丢失是 iOS 用户的普遍问题。由于意外删除、软件更新、被盗等多种原因&#xff0c;您可能会丢失重要文件。通过备份&#xff0c;您可以轻松找回 iPad上丢失的文件。但是&#xff0c;当您没有可用的备份时&#xff0c;麻烦就开始了。那么&#xff0c;如…

如何高效挖掘Web漏洞?

简介 SRC漏洞平台&#xff1a;安全应急响应中心&#xff08;SRC, Security Response Center&#xff09;&#xff0c;是企业用于对外接收来自用户发现并报告的产品安全漏洞的站点。说白了&#xff0c;就是连接白帽子和企业的平台&#xff0c;你去合法提交漏洞给他们&#xff0…

数据结构之树和森林

数据结构之树和森林 1、树的存储结构2、树和森林的遍历2.1、树的遍历2.2、森林的遍历 3、树、森林和二叉树之间的相互转换 数据结构是程序设计的重要基础&#xff0c;它所讨论的内容和技术对从事软件项目的开发有重要作用。学习数据结构要达到的目标是学会从问题出发&#xff0…

一键拥有你的GPT4

这几天我一直在帮朋友升级ChatGPT&#xff0c;现在已经可以闭眼操作了哈哈&#x1f61d;。我原本以为大家都已经用上GPT4&#xff0c;享受着它带来的巨大帮助时&#xff0c;但结果还挺让我吃惊的&#xff0c;还是有很多人仍苦于如何进行升级。所以就想着写篇教程来教会大家如何…

记录xxl-job重复执行引发业务问题

业务问题描述 1.创建运单&#xff0c;发现重复&#xff08;同一个车架号两条记录&#xff09; 2.通知重复反馈&#xff0c;A系统读取中间表状态为未处理数据&#xff0c;推送到B系统 原因分析 1.以上两个问题都是xxljob定时执行的 2.通过日志分析&#xff0c;读取中间表数…

pcl之滤波器(一)

pcl滤波器 pcl一共是有十二个主要模块&#xff0c;详细了解可以查看官网。https://pcl.readthedocs.io/projects/tutorials/en/latest/#basic-usage 今天学习一下pcl的滤波器模块。 滤波器模块&#xff0c;官网一共是提供了6个例程&#xff0c;今天先来看第一第二个。 直通…

01 Aras Innovator二次开发说明

在进行Aras Innovator二次开发之前&#xff0c;需要先了解Aras的服务器架构以及相关的方法论。 了解这部分内容后&#xff0c;有助于我们进行二次开发。 一. 服务器架构 参考下表&#xff1a; Aras Innovator为B/S架构&#xff0c;支持主流的浏览器(IE Edge,Firefox,Google)…

Labview for循环精讲

本文详细介绍Labview中For循环的使用方法&#xff0c;从所有细节让你透彻的看明白For循环是如何使用的&#xff0c;如果有帮助的话记得点赞加关注~ 1. For循环结构 从最简单的地方讲起&#xff0c;一个常用的for循环结构是由for循环结构框图、循环次数、循环计数(i)三部分组成…

Linux版本下载Centos操作

目录 一、Centos7 二、下载Centos7镜像 三、下载Centos7 买了个硬件安装裸机&#xff08;一堆硬件&#xff09; 把安装盘放到虚拟机里面&#xff0c;给机器加电 配置设置 ​编辑 网络配置 开启网络功能 四、安装linux客户端 Xshell是什么 Xshell使用&#xff08;连接…

构建一个安全可靠的身份认证中心和资源服务中心:SpringSecurity+OAuth2.0的完美结合

目录 1、引言 1.1 身份认证和授权的重要性 1.2 SpringSecurity和OAuth2.0的概述 2、架构设计 2.1 组件概述 2.2 身份认证中心的设计 2.3 资源服务中心的设计 3、身份认证中心的实现 3.1 用户管理 3.2 登录认证流程 3.3 令牌生成和管理 4、资源服务中心的实现 4.1 …

新版idea创建spring boot项目

目录 前言 汉化教程 项目模板初始化 1.点击新建项目 2.配置初始化信息 3.初始依赖选择 配置Maven 1.打开maven设置 2.重写maven配置文件 3.选择你创建的配置文件 4.重启项目 spring boot配置并测试 1.修改配置文件后缀 2.启动项目 3.编写测试控制类 4.重启项目…

idea引入jar包作为maven

1.引入jar包至项目中 2.配置当前项目的maven&#xff08;如果只想在本机能运行的话&#xff0c;到这一步就够了&#xff0c;后面pom配置也不需要这一步&#xff09; 3.配置文件的maven依赖路径 这里的 groupId 就是你引入原包的包路径&#xff0c;artifactId、version都是随…

【动态规划】【字符串】【C++算法】940. 不同的子序列 II

作者推荐 【动态规划】【广度优先搜索】【状态压缩】847 访问所有节点的最短路径 本文涉及知识点 动态规划汇总 LeetCode940. 不同的子序列 II 给定一个字符串 s&#xff0c;计算 s 的 不同非空子序列 的个数。因为结果可能很大&#xff0c;所以返回答案需要对 10^9 7 取…