Java从入门到精通-数组(三)

news2025/1/11 19:57:05

0. 数组

![在这里插入图片描述](https://img-blog.csdnimg.cn/1fbcd1668f4d42bf90e134d8d7bf2931.png

1. 数组概述

练习1: 创建一个整数数组,存储喜欢的5个数字,并编写代码打印出这些数字。

创建一个整数数组

public class Main {
    public static void main(String[] args) {
        // 创建一个整数数组,存储5个喜欢的数字
        int[] favoriteNumbers = {7, 22, 14, 42, 3};

        // 打印出这些数字
        System.out.println("我喜欢的数字:");
        for (int i = 0; i < favoriteNumbers.length; i++) {
            System.out.println(favoriteNumbers[i]);
        }
    }
}

案例分析:

  1. 在这个练习中,我们首先创建了一个名为 favoriteNumbers 的整数数组,其中包含了5个我们喜欢的数字。
  2. 使用 for 循环遍历数组,通过索引访问数组中的每个元素,并使用 System.out.println() 方法将它们打印出来。

案例总结:

  • 数组是一种数据结构,用于存储一组相同数据类型的元素,可以按顺序访问。
  • 创建数组时,我们需要指定数组的类型和长度,并可以通过初始化列表来初始化数组的元素。
  • 遍历数组是通过循环来实现的,通常使用 for 循环或增强型 for-each 循环来访问数组中的元素。
  • 数组是在Java中常见的数据结构之一,用于存储和处理大量的数据。在本例中,我们成功地创建了一个整数数组并打印了数组中的元素。这是数组概述中的一个简单示例,帮助我们理解了数组的基本概念和用法。

2. 一维数组

练习2: 创建一个字符串数组,包含一些水果的名称,然后使用循环遍历并打印数组中的水果名称。

创建一个字符串数组并遍历打印

public class Main {
    public static void main(String[] args) {
        // 创建一个字符串数组,包含一些水果的名称
        String[] fruits = {"苹果", "香蕉", "橙子", "葡萄", "樱桃"};

        // 使用循环遍历并打印数组中的水果名称
        System.out.println("水果列表:");
        for (int i = 0; i < fruits.length; i++) {
            System.out.println(fruits[i]);
        }
    }
}

案例分析:

  1. 在这个练习中,我们首先创建了一个名为 fruits 的字符串数组,其中包含了一些水果的名称。
  2. 使用 for 循环遍历数组,通过索引访问数组中的每个元素,并使用 System.out.println() 方法将它们打印出来。

案例总结:

  • 数组是一种数据结构,用于存储一组相同数据类型的元素,可以按顺序访问。
  • 在本例中,我们创建了一个字符串数组,用于存储水果的名称。
  • 使用循环遍历数组是一种常见的操作,可以使用 for 循环或增强型 for-each 循环来访问数组中的元素。
  • 数组在许多编程场景中都非常有用,它们允许我们有效地存储和处理多个数据元素。
  • 在这个示例中,我们成功地创建了一个字符串数组并打印了数组中的水果名称,这有助于理解数组的基本用法。

练习3: 编写一个程序,接受用户输入的一组数字,然后计算它们的平均值。

计算一组数字的平均值

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);

        // 提示用户输入一组数字
        System.out.print("请输入一组数字,以空格分隔:");
        String input = scanner.nextLine();

        // 使用空格分割输入字符串,将数字存储到数组中
        String[] numbersAsString = input.split(" ");
        double[] numbers = new double[numbersAsString.length];

        for (int i = 0; i < numbersAsString.length; i++) {
            numbers[i] = Double.parseDouble(numbersAsString[i]);
        }

        // 计算数字的平均值
        double sum = 0;
        for (double number : numbers) {
            sum += number;
        }

        double average = sum / numbers.length;

        // 打印平均值
        System.out.println("这组数字的平均值是:" + average);

        // 关闭Scanner
        scanner.close();
    }
}

案例分析:

  1. 在这个练习中,我们首先使用 Scanner 类接受用户的输入,要求用户输入一组数字,以空格分隔。
  2. 输入的字符串被分割成数字字符串数组,并通过循环将其转换为 double 类型的数组。
  3. 我们计算数字的总和,然后通过除以数字的数量来计算平均值。
  4. 最后,我们打印出计算得到的平均值。

案例总结:

  • 这个示例演示了如何使用Java中的数组来存储一组数字,以及如何计算这些数字的平均值。
  • Scanner 类用于接受用户输入,通过 split() 方法将输入字符串分割成数组,然后通过循环将字符串转换为数字。
  • 数组是一种有助于组织和处理大量数据的强大工具,它们允许我们进行各种数学和统计计算。
  • 通过这个练习,读者可以学习如何处理用户输入和使用数组来进行基本的数学操作。

3. 二维数组

练习4: 创建一个二维整数数组来表示一个九宫格数独游戏的初始状态,并编写代码打印出数独的初始状态。

创建并打印九宫格数独游戏的初始状态

public class Main {
    public static void main(String[] args) {
        // 创建一个二维整数数组来表示数独游戏的初始状态
        int[][] sudoku = {
            {5, 3, 0, 0, 7, 0, 0, 0, 0},
            {6, 0, 0, 1, 9, 5, 0, 0, 0},
            {0, 9, 8, 0, 0, 0, 0, 6, 0},
            {8, 0, 0, 0, 6, 0, 0, 0, 3},
            {4, 0, 0, 8, 0, 3, 0, 0, 1},
            {7, 0, 0, 0, 2, 0, 0, 0, 6},
            {0, 6, 0, 0, 0, 0, 2, 8, 0},
            {0, 0, 0, 4, 1, 9, 0, 0, 5},
            {0, 0, 0, 0, 8, 0, 0, 7, 9}
        };

        // 打印数独的初始状态
        System.out.println("数独的初始状态:");
        printSudoku(sudoku);
    }

    // 辅助方法:打印数独
    public static void printSudoku(int[][] sudoku) {
        for (int i = 0; i < sudoku.length; i++) {
            for (int j = 0; j < sudoku[i].length; j++) {
                System.out.print(sudoku[i][j] + " ");
            }
            System.out.println();
        }
    }
}

案例分析:

  1. 在这个练习中,我们创建了一个名为 sudoku 的二维整数数组,用于表示数独游戏的初始状态。数组中的0表示空格,其他数字表示已知的数。
  2. 我们使用 printSudoku 方法来打印数独的初始状态。该方法通过嵌套循环遍历二维数组,并逐行打印数独的格子。

案例总结:

  • 数组是一种用于存储和处理多维数据的强大工具。在这个示例中,我们使用二维整数数组来表示数独游戏的初始状态。
  • 使用嵌套循环可以有效地遍历二维数组的所有元素,并按照需要进行操作。
  • 数独游戏是一个经典的数学谜题,通过这个练习,读者可以学习如何使用数组来表示和处理游戏的状态

练习5: 编写一个程序,生成一个3x3的随机迷宫地图,其中包括起点、终点和墙壁。

生成随机迷宫地图

import java.util.Random;

public class Main {
    public static void main(String[] args) {
        // 定义迷宫地图的大小
        int rows = 3;
        int cols = 3;

        // 创建一个二维字符数组来表示迷宫地图
        char[][] maze = generateMaze(rows, cols);

        // 打印迷宫地图
        System.out.println("随机生成的迷宫地图:");
        printMaze(maze);
    }

    // 辅助方法:生成随机迷宫地图
    public static char[][] generateMaze(int rows, int cols) {
        char[][] maze = new char[rows][cols];
        Random random = new Random();

        // 随机设置起点、终点和墙壁
        for (int i = 0; i < rows; i++) {
            for (int j = 0; j < cols; j++) {
                int randomNumber = random.nextInt(3); // 生成0到2之间的随机数
                if (randomNumber == 0) {
                    maze[i][j] = 'S'; // 起点
                } else if (randomNumber == 1) {
                    maze[i][j] = 'E'; // 终点
                } else {
                    maze[i][j] = '#'; // 墙壁
                }
            }
        }

        return maze;
    }

    // 辅助方法:打印迷宫地图
    public static void printMaze(char[][] maze) {
        for (int i = 0; i < maze.length; i++) {
            for (int j = 0; j < maze[i].length; j++) {
                System.out.print(maze[i][j] + " ");
            }
            System.out.println();
        }
    }
}

案例分析:

  1. 在这个练习中,我们定义了迷宫地图的大小,并创建了一个二维字符数组 maze 用于表示迷宫地图。
  2. 使用 Random 类来生成随机的起点、终点和墙壁。我们通过生成0到2之间的随机数来确定地图上的元素,其中0表示起点,1表示终点,2表示墙壁。
  3. 最后,我们通过 printMaze 方法打印生成的迷宫地图。

案例总结:

  • 这个示例演示了如何使用Java中的二维字符数组来生成随机迷宫地图。
  • Random 类用于生成随机数,帮助创建不同的迷宫地图。
  • 数组在游戏开发、地图生成和模拟等应用中经常被用来表示复杂的场景和状态。
  • 通过这个练习,读者可以学习如何使用数组来构建随机生成的迷宫地图,这有助于理解数组在游戏编程中的应用。

4. 数组的基本操作

练习6: 编写一个程序,接受用户输入的一组数字,并查找其中的最大值和最小值。

查找一组数字的最大值和最小值

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);

        // 提示用户输入一组数字,以空格分隔
        System.out.print("请输入一组数字,以空格分隔:");
        String input = scanner.nextLine();

        // 使用空格分割输入字符串,将数字存储到数组中
        String[] numbersAsString = input.split(" ");
        double[] numbers = new double[numbersAsString.length];

        for (int i = 0; i < numbersAsString.length; i++) {
            numbers[i] = Double.parseDouble(numbersAsString[i]);
        }

        // 查找最大值和最小值
        double max = findMax(numbers);
        double min = findMin(numbers);

        // 打印最大值和最小值
        System.out.println("最大值是:" + max);
        System.out.println("最小值是:" + min);

        // 关闭Scanner
        scanner.close();
    }

    // 辅助方法:查找数组中的最大值
    public static double findMax(double[] numbers) {
        double max = numbers[0];
        for (double number : numbers) {
            if (number > max) {
                max = number;
            }
        }
        return max;
    }

    // 辅助方法:查找数组中的最小值
    public static double findMin(double[] numbers) {
        double min = numbers[0];
        for (double number : numbers) {
            if (number < min) {
                min = number;
            }
        }
        return min;
    }
}

案例分析:

  1. 在这个练习中,我们使用 Scanner 类接受用户的输入,要求用户输入一组数字,以空格分隔。
  2. 输入的字符串被分割成数字字符串数组,并通过循环将其转换为 double 类型的数组。
  3. 我们编写两个辅助方法 findMax 和 findMin 来分别查找数组中的最大值和最小值。
  4. 最后,我们打印出找到的最大值和最小值。

案例总结:

  • 这个示例演示了如何使用Java来查找一组数字的最大值和最小值。
  • Scanner 类用于接受用户输入,通过 split() 方法将输入字符串分割成数组,然后通过循环将字符串转换为数字。
  • 数组是一种有助于存储和处理多个数据元素的工具,可以用于各种数学和统计计算。
  • 通过这个练习,读者可以学习如何处理用户输入并使用数组来进行基本的数学操作,如查找最大值和最小值。

练习7: 创建两个整数数组,分别表示两个向量的坐标,然后编写代码计算这两个向量的点积(内积)。

计算两个向量的点积

public class Main {
    public static void main(String[] args) {
        // 创建两个整数数组,分别表示两个向量的坐标
        int[] vector1 = {2, 3, -1};
        int[] vector2 = {1, -2, 2};

        // 计算两个向量的点积
        int dotProduct = calculateDotProduct(vector1, vector2);

        // 打印点积结果
        System.out.println("两个向量的点积是:" + dotProduct);
    }

    // 辅助方法:计算两个向量的点积
    public static int calculateDotProduct(int[] vector1, int[] vector2) {
        if (vector1.length != vector2.length) {
            throw new IllegalArgumentException("向量长度不一致");
        }

        int dotProduct = 0;
        for (int i = 0; i < vector1.length; i++) {
            dotProduct += vector1[i] * vector2[i];
        }

        return dotProduct;
    }
}

案例分析:

  1. 在这个练习中,我们首先创建了两个整数数组 vector1 和 vector2,它们分别表示两个向量的坐标。
  2. 我们编写了一个辅助方法 calculateDotProduct 来计算两个向量的点积。
  3. 点积的计算是通过遍历两个向量的坐标并对应相乘后累加得到的。

案例总结:

  • 这个示例演示了如何使用Java来计算两个向量的点积(内积)。
  • 辅助方法 calculateDotProduct 接受两个整数数组,先检查它们的长度是否一致,然后计算点积。
  • 数组是一种有助于进行向量和矩阵运算的工具,它们常用于线性代数和数学领域的计算。
  • 通过这个练习,读者可以学习如何使用数组来进行向量运算,以及如何编写和调用自定义的辅助方法。

5. 数组排列算法

练习8: 使用冒泡排序或选择排序对一个整数数组进行升序排列,并打印排序后的数组。
以下是使用Java回答 “数组排列算法” 模块中的练习8的示例,采用冒泡排序算法,并包括解释和总结:

使用冒泡排序对整数数组进行升序排列

public class Main {
    public static void main(String[] args) {
        int[] numbers = {5, 2, 9, 1, 5, 6};

        System.out.println("排序前的数组:");
        printArray(numbers);

        // 使用冒泡排序算法对数组进行升序排列
        bubbleSort(numbers);

        System.out.println("排序后的数组:");
        printArray(numbers);
    }

    // 冒泡排序算法
    public static void bubbleSort(int[] arr) {
        int n = arr.length;
        boolean swapped;

        for (int i = 0; i < n - 1; i++) {
            swapped = false;

            for (int j = 0; j < n - i - 1; j++) {
                if (arr[j] > arr[j + 1]) {
                    // 交换arr[j]和arr[j+1]的位置
                    int temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                    swapped = true;
                }
            }

            // 如果内循环没有发生交换,表示数组已排序完成,可以提前退出
            if (!swapped) {
                break;
            }
        }
    }

    // 打印数组
    public static void printArray(int[] arr) {
        for (int num : arr) {
            System.out.print(num + " ");
        }
        System.out.println();
    }
}

案例分析:

  1. 在这个练习中,我们首先创建了一个整数数组 numbers,包含一些未排序的整数。
  2. 使用冒泡排序算法来对数组进行升序排列,排序后的数组将覆盖原始数组。
  3. 冒泡排序算法的核心思想是依次比较相邻的元素并交换它们,将较大的元素逐步向右移动。
  4. 我们使用 printArray 方法来打印排序前和排序后的数组。

案例总结:

  • 这个示例演示了如何使用Java实现冒泡排序算法来对整数数组进行升序排列。
  • 冒泡排序是一种简单但不高效的排序算法,它依次比较相邻元素并交换它们,直到数组完全有序。
  • 冒泡排序适用于小型数据集,但在大型数据集上性能较差。
  • 通过这个练习,读者可以学习排序算法的基本原理和实现方式,以及如何应用它们来排序数组。

练习9: 编写一个程序,生成一个包含10个随机整数的数组,并使用快速排序算法对其进行排序。
以下是使用Java回答 “数组排列算法” 模块中的练习9的示例,采用快速排序算法,并包括解释和总结:

使用快速排序对包含10个随机整数的数组进行排序

import java.util.Random;

public class Main {
    public static void main(String[] args) {
        int[] numbers = generateRandomArray(10);

        System.out.println("排序前的数组:");
        printArray(numbers);

        // 使用快速排序算法对数组进行升序排列
        quickSort(numbers, 0, numbers.length - 1);

        System.out.println("排序后的数组:");
        printArray(numbers);
    }

    // 快速排序算法
    public static void quickSort(int[] arr, int low, int high) {
        if (low < high) {
            int pivotIndex = partition(arr, low, high);

            // 递归排序左半部分和右半部分
            quickSort(arr, low, pivotIndex - 1);
            quickSort(arr, pivotIndex + 1, high);
        }
    }

    // 快速排序的分区函数
    public static int partition(int[] arr, int low, int high) {
        int pivot = arr[high];
        int i = low - 1;

        for (int j = low; j < high; j++) {
            if (arr[j] < pivot) {
                i++;
                // 交换arr[i]和arr[j]的位置
                int temp = arr[i];
                arr[i] = arr[j];
                arr[j] = temp;
            }
        }

        // 交换arr[i+1]和arr[high]的位置,将pivot放到正确的位置
        int temp = arr[i + 1];
        arr[i + 1] = arr[high];
        arr[high] = temp;

        return i + 1;
    }

    // 生成包含n个随机整数的数组
    public static int[] generateRandomArray(int n) {
        int[] arr = new int[n];
        Random random = new Random();

        for (int i = 0; i < n; i++) {
            arr[i] = random.nextInt(100); // 生成0到99之间的随机整数
        }

        return arr;
    }

    // 打印数组
    public static void printArray(int[] arr) {
        for (int num : arr) {
            System.out.print(num + " ");
        }
        System.out.println();
    }
}

案例分析:

  1. 在这个练习中,我们首先生成包含10个随机整数的数组 numbers
  2. 使用快速排序算法 quickSort 对数组进行升序排列。
  3. 快速排序算法的核心思想是选择一个基准元素(这里选择最后一个元素),将数组分为两部分,左边部分小于基准元素,右边部分大于基准元素,然后递归排序左右两部分。
  4. 我们使用 generateRandomArray 方法来生成随机数组,并使用 printArray 方法来打印排序前和排序后的数组。

案例总结:

  • 这个示例演示了如何使用Java实现快速排序算法来对包含随机整数的数组进行升序排列。
  • 快速排序是一种高效的排序算法,平均时间复杂度为 O(nlogn)。
  • 快速排序的关键是分区(partition)过程,它将数组分为两部分并递归排序,直到整个数组有序。
  • 通过这个练习,读者可以学习排序算法的高效性和递归算法的应用。

6. 实践与练习

练习10: 创建一个简单的任务管理程序,使用数组来存储任务的描述和状态(未完成/已完成),并提供选项来添加、查看和标记任务的状态。

import java.util.Scanner;

public class TaskManager {
    private static final int MAX_TASKS = 100; // 最大任务数量
    private String[] tasks; // 存储任务的描述
    private boolean[] taskStatus; // 存储任务的状态,true表示已完成,false表示未完成
    private int taskCount; // 任务数量

    public TaskManager() {
        tasks = new String[MAX_TASKS];
        taskStatus = new boolean[MAX_TASKS];
        taskCount = 0;
    }

    // 添加新任务
    public void addTask(String description) {
        if (taskCount < MAX_TASKS) {
            tasks[taskCount] = description;
            taskStatus[taskCount] = false; // 默认设置为未完成
            taskCount++;
            System.out.println("任务已添加!");
        } else {
            System.out.println("任务列表已满,无法添加新任务。");
        }
    }

    // 查看任务列表
    public void viewTasks() {
        if (taskCount == 0) {
            System.out.println("任务列表为空。");
        } else {
            System.out.println("任务列表:");
            for (int i = 0; i < taskCount; i++) {
                String status = taskStatus[i] ? "[已完成]" : "[未完成]";
                System.out.println(status + " " + (i + 1) + ". " + tasks[i]);
            }
        }
    }

    // 标记任务状态
    public void markTaskCompleted(int index) {
        if (index >= 1 && index <= taskCount) {
            taskStatus[index - 1] = true;
            System.out.println("任务已标记为已完成。");
        } else {
            System.out.println("无效的任务索引。");
        }
    }

    public static void main(String[] args) {
        TaskManager taskManager = new TaskManager();
        Scanner scanner = new Scanner(System.in);

        while (true) {
            System.out.println("任务管理程序选项:");
            System.out.println("1. 添加新任务");
            System.out.println("2. 查看任务列表");
            System.out.println("3. 标记任务为已完成");
            System.out.println("4. 退出程序");
            System.out.print("请选择操作(1/2/3/4):");

            int choice = scanner.nextInt();
            scanner.nextLine(); // 消耗换行符

            switch (choice) {
                case 1:
                    System.out.print("请输入任务描述:");
                    String description = scanner.nextLine();
                    taskManager.addTask(description);
                    break;
                case 2:
                    taskManager.viewTasks();
                    break;
                case 3:
                    System.out.print("请输入要标记为已完成的任务索引:");
                    int index = scanner.nextInt();
                    taskManager.markTaskCompleted(index);
                    break;
                case 4:
                    System.out.println("程序已退出。");
                    scanner.close();
                    System.exit(0);
                default:
                    System.out.println("无效的选项,请重新选择。");
                    break;
            }
        }
    }
}

案例分析:

  1. 这个示例创建了一个名为 TaskManager 的任务管理程序类,使用数组来存储任务的描述和状态(未完成/已完成)。
  2. 用户可以通过选项来添加新任务、查看任务列表和标记任务状态。
  3. 主程序部分使用一个无限循环,用户可以根据提示选择不同的操作。
  4. 使用 Scanner 类来接受用户的输入。

案例总结:

  • 这个示例演示了如何使用Java创建一个简单的任务管理程序,它使用数组来存储任务信息并提供基本的操作选项。
  • 数组在这个程序中用于存储任务描述和状态,可以轻松地扩展功能以满足更复杂的需求。
  • 通过这个练习,读者可以学习如何使用数组和基本的控制结构来创建一个小型的命令行程序,这有助于理解数组在实际应用中的用途。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

G4学术期刊《中学教学参考》简介及投稿要求

G4学术期刊《中学教学参考》简介及投稿要求 《中学教学参考》为广西教育学院杂志社主办的国内外公开发行刊物&#xff0c;坚持为基础教育服务的宗旨&#xff0c;竭诚为全国教育工作者服务&#xff0c;提供最新教改信息和教育理论成果&#xff0c;为广大教育工作者交流经验、发…

python系列:requests库+BS4库及综合实例

仅供学习、交流使用&#xff0c;不具有任何商业用途&#xff0c;如有问题请及时联系我们以作处理。 文章目录 前言requests安装使用第一种 requests.request("请求方式", ...)第二种 requests.请求方式(参数)URL中传递参数 paramsxx响应内容 r.text二进制响应内容 r.…

从零开始的PICO教程(1)Pico游戏开发项目配置

从零开始的PICO教程&#xff08;1&#xff09;Pico游戏开发项目配置 文章目录 从零开始的PICO教程&#xff08;1&#xff09;Pico游戏开发项目配置一、前言1、大纲 二、成为Pico开发者1、注册 PICO 开发者帐号2、创建组织3、创建应用 三、导入PICO的SDK1、PICO设备开启 “开发者…

一文了解数据科学Notebook

编者按&#xff1a; 主要介绍什么是Notebook&#xff0c;Notebook在数据科学领域的应用的重要性与优势&#xff0c;以及数据科学家/算法团队在选择Notebook时需考虑哪些关键因素。同时&#xff0c;基于Notebook的筛选考量维度&#xff0c;对常见的Notebook进初步对比分析&#…

volatile、ReentrantLock和synchronized保证线程可见性原理

主存、工作内存 在了解什么是线程可见性前&#xff0c;我们先来简单了解下 Java内存模型 的主存、工作内存抽象概念 主存&#xff1a; 存储的是一些共享资源的存储位置&#xff08;例如静态变量等&#xff09; 工作内存&#xff1a; 每个线程对应的栈内存对应的私有局部…

JAVASE 游戏

朴素的拼图游戏&#xff0c;通过WASD移动&#xff0c;我自己都不太会&#xff0c;可以通过篡改内部代码来取得想要的成功彩蛋 代码&#xff1a; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.KeyEvent; import java.awt.…

如何使用autotools制作Makefile

本文将通过一个例子介绍如何使用autotools制作Makefile&#xff0c;最终运行可执行文件。 本例子中使用的源代码a.c如下。 #include "stdio.h" void main() {int a,b;int c;printf("请输入两个数&#xff1a;\n");scanf("%d %d",&a,&b)…

大数据课程L3——网站流量项目的系统搭建

文章作者邮箱:yugongshiye@sina.cn 地址:广东惠州 ▲ 本章节目的 ⚪ 了解网站流量项目的运行环境; ⚪ 了解网站流量项目的日志采集系统搭建; ⚪ 了解网站流量项目的离线业务系统搭建; ⚪ 了解网站流量项目的Hive做离线数据处理; ⚪ 了解网站流量项目的…

盲打键盘的正确指法指南

简介 很多打字初学者&#xff0c;并不了解打字的正确指法规范&#xff0c;很容易出现只用两根手指交替按压键盘的“二指禅”情况。虽然这样也能实现打字&#xff0c;但是效率极低。本文将简单介绍盲打键盘的正确指法&#xff0c;以便大家在后续的学习和工作中能够提高工作效率…

Nacos安装及在项目中的使用

目录 概要一、安装 Nacos1、下载 Nacos2、解压3、启动 Nacos 服务器4、自定义Nacos启动脚本5、访问Nacos Web控制台 二、Nacos----服务注册与发现1、添加 Nacos 依赖2、配置 Nacos 服务器地址3、使用 Nacos 注册服务4、启动服务 三、Nacos----配置管理1、创建配置数据2、从 Nac…

技师学院物联网实训室建建设方案

一、概述 1.1专业背景 物联网&#xff08;Internet of Things&#xff09;被称为继计算机、互联网之后世界信息产业第三次浪潮&#xff0c;它并非一个全新的技术领域&#xff0c;而是现代信息技术发展到一定阶段后出现的一种聚合性应用与技术提升&#xff0c;是随着传感网、通…

深圳站WOT全球技术创新大会2023,精彩即将开启!

前几天刷屏的“中国大模型顶流群聊笔记”想必很多人都看到了&#xff0c;包括百川智能创始人&CEO王小川&#xff0c;创新工场董事长、零一万物创始人李开复&#xff0c;澜舟科技CEO周明在内的20多位中国大模型领域模型层、工具层、应用层的“顶流”们&#xff0c;在西溪湿地…

【校招VIP】专业课考点之死锁

考点介绍&#xff1a; 在两个或者多个并发进程中&#xff0c;如果每个进程持有某种资源而又等待其它进程释放它或它们现在保持着的资源&#xff0c;在未改变这种状态之前都不能向前推进&#xff0c;称这一组进程产生了死锁。通俗的讲就是两个或多个进程无限期的阻塞、相互等待的…

使用Python和BeautifulSoup提取网页数据的实用技巧

在数据驱动的时代&#xff0c;获取网页数据并进行分析和处理是一项重要的任务。Python作为一门强大的编程语言&#xff0c;在处理网页数据的领域也表现出色。本文将分享使用Python和BeautifulSoup库提取网页数据的实用技巧&#xff0c;帮助你更高效地获取和处理网页数据。 1、了…

什么牌子的运动蓝牙耳机好用、运动耳机品牌排行榜推荐

运动与健康息息相关&#xff0c;人们越来越认识到运动带来的益处&#xff0c;例如增强心肺功能、提高新陈代谢率&#xff0c;并能预防多种慢性疾病。随着社交媒体上越来越多人分享自己的运动心得&#xff0c;更多的人也被激发起参与其中的热情。 在运动过程中&#xff0c;音乐的…

猫头虎博主赠书三期:《Go编程进阶实战: 开发命令行应用、HTTP应用和gRPC应用》

&#x1f389;猫头虎博主赠书三期&#x1f389;&#xff1a;《Go编程进阶实战: 开发命令行应用、HTTP应用和gRPC应用》 &#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页…

EditPlus 配置python 及Anaconda中的python

若不是pycharm vscode 太大&#xff0c;太占内存&#xff0c;谁会想到用Notepad&#xff0c;EdirPlus 配置python呢&#xff01;&#xff01;&#xff01; 话不多说&#xff0c;首先你自己安装好EditPlus。开始 菜单栏 选择 工具 -> 配置自定义工具 组名:python 命令:d:\*…

基于51单片机的称重电子秤proteus仿真设计

一、设计背景 随着微电子技术的应用,市场上使用的传统称重工具已经满足不了人们的要求。为了改变传统称重工具在使用上存在的问题&#xff0c;在本设计中将智能化、自动化、人性化用在了电子秤重的控制系统中。本系统主要由单片机来控制&#xff0c;测量物体重量部分使用称重传…

雅思口语同替高分表达

目录 雅思口语题目准备 Riding a bike 1. Did you have a bike when you were young? 2. Did you ride a bike when you were little? 3. Did you ride a bike to school? 4. Do you ride a bike when you go out no? 雅思口语经验 口语高分同替词汇 中式英语问题…

计算机竞赛 基于生成对抗网络的照片上色动态算法设计与实现 - 深度学习 opencv python

文章目录 1 前言1 课题背景2 GAN(生成对抗网络)2.1 简介2.2 基本原理 3 DeOldify 框架4 First Order Motion Model5 最后 1 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 基于生成对抗网络的照片上色动态算法设计与实现 该项目较为新颖&am…