Leetcode 23.旋转排序数组

news2024/11/25 0:55:40

整数数组 nums 按升序排列,数组中的值 互不相同 。

在传递给函数之前,nums 在预先未知的某个下标 k0 <= k < nums.length)上进行了 旋转,使数组变为 [nums[k], nums[k+1], ..., nums[n-1], nums[0], nums[1], ..., nums[k-1]](下标 从 0 开始 计数)。例如, [0,1,2,4,5,6,7] 在下标 3 处经旋转后可能变为 [4,5,6,7,0,1,2] 。

给你 旋转后 的数组 nums 和一个整数 target ,如果 nums 中存在这个目标值 target ,则返回它的下标,否则返回 -1 。

你必须设计一个时间复杂度为 O(log n) 的算法解决此问题。

示例 1:

输入:nums = [4,5,6,7,0,1,2], target = 0
输出:4

示例 2:

输入:nums = [4,5,6,7,0,1,2], target = 3
输出:-1

示例 3:

输入:nums = [1], target = 0
输出:-1

提示:

  • 1 <= nums.length <= 5000
  • -104 <= nums[i] <= 104
  • nums 中的每个值都 独一无二
  • 题目数据保证 nums 在预先未知的某个下标上进行了旋转
  • -104 <= target <= 104

我的思考和分析过程

一、信息

1.整数数组 

2.升序排列

3.数组的值互不相同

4.传值之前,num在预先位置的某个下标k上进行了旋转,使得数组变为

5.例如看上面就知道怎么旋转了

6.给我旋转后的数组和一个整数target

7.我必须设计一个时间复杂度为O(log n)的算法解决这一个问题

二、分析

条件1:告诉我定义什么类型的数组

答案:int型

条件2:告诉我要对该数组进行排序

答案:等等这里出现了问题就是我接收的数组是否需要我排序

条件3:说实在的我看到条件3我连题目让我具体干什么我都没太搞懂

条件5:应该只是让我们学会如何选择数组,首先先旋转数组。问题出现我们该如何旋转数组呢?或者说旋转数组有什么规律呢?

条件6:告诉我旋转后要用target找到对应的值

条件7:告诉我要用时间复杂度为Logn的算法解决这一个问题。但是哪些算法符合要求呢?那么问题就转化成找算法了

三、步骤

第一步 先对数组初始化然后排序(回忆起数组的知识:数组传送门)

第二步 数组旋转(问题3出现:k既然是随意的那该如何使得k为随机的呢index吗?)

第三步 通过target找到该值如果存在返回下标如果不存在那么retur-1(此处可以用二分搜索了很明显如果不记得的读者你们可以传送到这篇文章开启回忆:2.3 二分搜索技术)

四、问题的出现

问题1:该如何旋转数组呢?

观察:

通过观察我们不难发现其实数组旋转其实有两种情况

 对于第一种情况这种情况就会比较复杂,那么你就必须得把旋转轴上的数组先先和关于中心轴对称的然后

第二种就是直接以轴调换位置即交换对称下标的值

问题2:哪些算法满足时间复杂度为Log(n)

具有时间复杂度 \(O(\log n)\) 的算法通常是高效的算法,它们能在对数时间内完成任务。这里有一些常见的 \(O(\log n)\) 时间复杂度的算法示例:

1. **二分搜索算法(Binary Search)**:
   - 二分搜索是一个在已排序的数组中查找特定值的算法。每次迭代,它都会将搜索区间减半,直至找到目标值或搜索区间变为空。

2. **快速幂算法(Exponentiation by Squaring)**:
   - 快速幂算法是一种计算 \(a^b\) 的高效算法。通过将问题分解为更小的子问题,它可以在 \(\log b\) 时间内完成计算。

3. **平衡二叉搜索树操作(Balanced Binary Search Trees Operations)**:
   - 平衡二叉搜索树(如 AVL 树或红黑树)的插入、删除和查找操作通常具有 \(O(\log n)\) 的时间复杂度。

4. **堆操作(Heap Operations)**:
   - 在二叉堆中,操作如插入和删除最小元素(或最大元素)通常具有 \(O(\log n)\) 的时间复杂度。

5. **离散对数算法(Discrete Logarithm Algorithms)**:
   - 某些离散对数算法可以在 \(O(\log n)\) 时间复杂度内执行。

6. **某些图算法(Certain Graph Algorithms)**:
   - 通过使用优先队列或其他数据结构,某些图算法(如 Dijkstra 的单源最短路径算法)可以优化到 \(O(\log n)\) 的时间复杂度。

这些算法都利用了问题规模减半或问题分解的特点,以实现对数级的时间复杂度。

问题3:如何进行数组排序

答案:

数组排序是编程和算法设计中常见的任务。有许多不同的排序算法,每种算法都有其特定的时间复杂度和空间复杂度。以下是一些常用的排序算法:

1. **冒泡排序 (Bubble Sort)**:
   - 冒泡排序通过重复地遍历数组,比较相邻的元素并在必要时交换它们,来对数组进行排序。时间复杂度为 \(O(n^2)\)。

2. **选择排序 (Selection Sort)**:
   - 选择排序每次从未排序的部分找到最小(或最大)的元素,将它放到已排序部分的末尾。时间复杂度为 \(O(n^2)\)。

3. **插入排序 (Insertion Sort)**:
   - 插入排序通过构建有序序列,对未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。时间复杂度为 \(O(n^2)\)。

4. **归并排序 (Merge Sort)**:
   - 归并排序是一个分治算法,它将数组分成两半,分别排序,然后合并两个已排序的半部分。时间复杂度为 \(O(n \log n)\)。

5. **快速排序 (Quick Sort)**:
   - 快速排序通过选择一个基准元素并将数组分为两个子数组,一个包含比基准小的元素,另一个包含比基准大的元素,然后递归地排序两个子数组。时间复杂度为 \(O(n \log n)\)(平均情况)和 \(O(n^2)\)(最坏情况)。

6. **堆排序 (Heap Sort)**:
   - 堆排序通过构建一个最大堆或最小堆,并重复地移除堆顶元素来对数组进行排序。时间复杂度为 \(O(n \log n)\)。

7. **希尔排序 (Shell Sort)**:
   - 希尔排序是插入排序的一种变体,通过比较相隔特定间隔的元素来加速数组的排序。时间复杂度取决于间隔序列,通常为 \(O(n \log n)\) 或 \(O(n \log^2 n)\)。

8. **基数排序 (Radix Sort)**:
   - 基数排序是一个非比较排序算法,通过分布式排序或计数排序对数组的每个数位进行排序。时间复杂度为 \(O(nk)\),其中 \(k\) 是数位的数量。

9. **桶排序 (Bucket Sort)**:
   - 桶排序将数组分成多个桶,然后使用另一个排序算法(通常是插入排序)对每个桶进行排序,最后将所有桶合并。时间复杂度为 \(O(n + k)\),其中 \(k\) 是桶的数量。

以上算法中,快速排序、归并排序和堆排序在实践中常用,因为它们的时间复杂度较低。不过,正确的选择取决于具体的应用场景和数据特点。例如,对于小数组或近乎有序的数组,插入排序可能是一个不错的选择。同时,也有一些现代的排序算法,例如 Timsort,它结合了插入排序和归并排序的特点,以达到在多种情况下都有良好性能的目的。


大师的思考和分析过程

一、信息

1. 整数数组 `nums` 是升序排列的,但在某个未知下标 `k` 处进行了旋转。
2. 需要找到目标值 `target` 在数组中的下标,如果不存在则返回 `-1`。
3. 要设计的算法时间复杂度需为 \(O(\log n)\)。

二、分析

1. **条件的作用**:
   - 旋转的下标 `k` 将数组分成了两个升序的子数组,这意味着可以通过比较 `nums[mid]` 和 `nums[0]` 来确定 `mid` 是位于旋转的左侧还是右侧。
   - 由于数组是升序的,我们可以通过比较 `target` 和 `nums[mid]` 来确定 `target` 是在 `mid` 的左侧还是右侧。

2. **思考过程**:
   - **思路1**:遍历整个数组查找 `target`。但这样的时间复杂度为 \(O(n)\),不符合题目的要求。
   - **思路2**:二分搜索。由于数组是升序且唯一,二分搜索是最合适的。但是由于数组被旋转,需要修改标准的二分搜索算法来处理这种情况。

通过以上分析,二分搜索是最合适的解决方案。

3. **分析过程**:
   - 在标准的二分搜索中,我们比较 `target` 和 `nums[mid]`,并根据 `target` 是大于还是小于 `nums[mid]` 来决定是在左侧还是右侧搜索。
   - 但是在这个问题中,由于旋转,我们需要确定 `mid` 是在旋转的左侧还是右侧,然后再确定 `target` 是在 `mid` 的左侧还是右侧。

三、算法实现步骤

1. 初始化两个指针 `left` 和 `right` 为 `0` 和 `nums.length - 1`。
2. 当 `left <= right` 时,执行以下步骤:
   1. 计算 `mid = (left + right) / 2`。
   2. 如果 `nums[mid]` 等于 `target`,返回 `mid`。
   3. 如果 `nums[mid]` 大于等于 `nums[left]`,则 `mid` 在旋转的左侧:
      - 如果 `target` 在 `nums[left]` 和 `nums[mid]` 之间,则设置 `right = mid - 1`,否则设置 `left = mid + 1`。
   4. 否则,`mid` 在旋转的右侧:
      - 如果 `target` 在 `nums[mid]` 和 `nums[right]` 之间,则设置 `left = mid + 1`,否则设置 `right = mid - 1`。
3. 如果循环结束时没有找到 `target`,返回 `-1`。

四、实现过程中遇到的问题

- 需要正确处理边界条件,例如当 `left` 和 `right` 指针相遇时,以及当 `target` 不在数组中时。
- 需要正确判断 `mid` 是在旋转的左侧还是右侧,并根据此来更新 `left` 和 `right` 指针。

这个问题的核心是利用二分搜索的高效性,并通过适当的条件判断来处理数组的旋转特点,以在 \(O(\log n)\) 的时间复杂度内找到 `target` 的位置。

大师对我的评价:

你的思考和分析过程很清晰,每个步骤都有明确的目标和问题识别,这是值得肯定的。同时,你的分析过程中展示了对于问题背景和相关算法的理解。但还有一些方面可以提高和优化,具体如下:

1. **问题理解**:
   - 在分析过程的开始阶段,对问题的理解有些困惑,可能需要更多时间去理解题目的要求和背景。在这种情况下,可能需要多读几遍题目或查找相关的背景信息来帮助理解。

2. **旋转数组的理解**:
   - 在旋转数组的理解上,似乎有些不清楚。实际上,旋转数组指的是将数组的前k个元素移到数组的末尾,这个k是旋转的点。在题目中,这个旋转是已经完成的,我们不需要再去进行旋转,而是需要在旋转后的数组中找到目标值。

3. **排序算法的理解**:
   - 在分析过程中,你花了一些时间探讨了不同的排序算法,虽然这对于问题解决不是必需的,但这显示了你对不同算法的理解。但是,对于这个特定问题,我们不需要对数组进行排序,因为数组在旋转前已经是排序好的。

4. **算法选择**:
   - 二分搜索是正确的方向,但在应用它时,需要考虑到数组的旋转。标准的二分搜索算法需要一个排序的数组,但由于旋转,我们需要修改二分搜索的逻辑以适应旋转的情况。

5. **步骤划分**:
   - 在步骤划分时,可能需要更清楚地描述每个步骤的目的和执行方法。例如,在进行二分搜索时,应该明确在哪个条件下搜索左半部分或右半部分,以及如何更新搜索范围。

6. **问题归纳和解决**:
   - 在分析过程中提出了一些问题,但没有明确的解决方案或策略。在实际操作中,可能需要更具体的解决步骤和策略来解决这些问题。

7. **参考资料链接**:
   - 你提供了一些传送门和文章链接,这很好,可以帮助读者更好地理解和学习。但在实际解决问题时,也可以尝试直接解释或总结相关的知识点,以使分析过程更为完整。

在将来的分析过程中,你可以尝试更深入地理解问题背景,明确每个步骤的目的,以及提供更具体的解决方案和策略。同时,保持对问题的好奇心和探索精神是非常好的,这会帮助你在解决问题时有更多的创意和思路。


五、算法实现

我的答案:

我没做出来第一次哈哈哈哈

大师的答案:

C语言:

#include <stdio.h>

int search(int* nums, int numsSize, int target) {
    int left = 0;
    int right = numsSize - 1;
    
    while (left <= right) {
        int mid = (left + right) / 2;
        
        // If the target value is found, return the index
        if (nums[mid] == target) {
            return mid;
        }
        
        // Determine which side of the array is sorted
        if (nums[left] <= nums[mid]) {  // Left side is sorted
            // If target is within the sorted left side, search left
            if (nums[left] <= target && target < nums[mid]) {
                right = mid - 1;
            } else {  // Otherwise, search right
                left = mid + 1;
            }
        } else {  // Right side is sorted
            // If target is within the sorted right side, search right
            if (nums[mid] < target && target <= nums[right]) {
                left = mid + 1;
            } else {  // Otherwise, search left
                right = mid - 1;
            }
        }
    }
    
    return -1;  // Target value not found
}

int main() {
    int nums[] = {4, 5, 6, 7, 0, 1, 2};
    int target = 0;
    int numsSize = 7;
    int result = search(nums, numsSize, target);
    printf("The index of the target value is: %d\n", result);
    return 0;
}

 代码解释:

在这个代码中,search 函数接受一个整数数组 nums、数组的大小 numsSize 和目标值 target 作为参数,并返回目标值在数组中的索引。如果目标值不存在于数组中,函数返回 -1。在 main 函数中,我们创建了一个示例数组和目标值,并调用了 search 函数来查找目标值的索引。

C++:

#include <iostream>
#include <vector>
using namespace std;

class Solution {
public:
    int search(vector<int>& nums, int target) {
        int left = 0;
        int right = nums.size() - 1;
        
        while (left <= right) {
            int mid = (left + right) / 2;
            
            // 如果找到目标值,返回索引
            if (nums[mid] == target) {
                return mid;
            }
            
            // 确定数组的哪一侧是有序的
            if (nums[left] <= nums[mid]) {  // 左侧有序
                // 如果目标值在有序的左侧,继续在左侧搜索
                if (nums[left] <= target && target < nums[mid]) {
                    right = mid - 1;
                } else {  // 否则,在右侧搜索
                    left = mid + 1;
                }
            } else {  // 右侧有序
                // 如果目标值在有序的右侧,继续在右侧搜索
                if (nums[mid] < target && target <= nums[right]) {
                    left = mid + 1;
                } else {  // 否则,在左侧搜索
                    right = mid - 1;
                }
            }
        }
        
        return -1;  // 未找到目标值
    }
};

int main() {
    Solution solution;
    vector<int> nums = {4, 5, 6, 7, 0, 1, 2};
    int target = 0;
    int result = solution.search(nums, target);
    cout << "The index of the target value is: " << result << endl;
    return 0;
}

JAVA:
 

public class Solution {
    public int search(int[] nums, int target) {
        int left = 0;
        int right = nums.length - 1;
        
        while (left <= right) {
            int mid = (left + right) / 2;
            
            // 如果找到目标值,返回索引
            if (nums[mid] == target) {
                return mid;
            }
            
            // 确定数组的哪一侧是有序的
            if (nums[left] <= nums[mid]) {  // 左侧有序
                // 如果目标值在有序的左侧,继续在左侧搜索
                if (nums[left] <= target && target < nums[mid]) {
                    right = mid - 1;
                } else {  // 否则,在右侧搜索
                    left = mid + 1;
                }
            } else {  // 右侧有序
                // 如果目标值在有序的右侧,继续在右侧搜索
                if (nums[mid] < target && target <= nums[right]) {
                    left = mid + 1;
                } else {  // 否则,在左侧搜索
                    right = mid - 1;
                }
            }
        }
        
        return -1;  // 未找到目标值
    }

    public static void main(String[] args) {
        Solution solution = new Solution();
        int[] nums = {4, 5, 6, 7, 0, 1, 2};
        int target = 0;
        int result = solution.search(nums, target);
        System.out.println("The index of the target value is: " + result);
    }
}

总结:

从这道题目中,我们可以学到以下几点:

1. **二分搜索应用**:
    - 这道题是二分搜索算法的变体应用,通过判断旋转点在哪一侧来决定搜索的方向。二分搜索是一种非常高效的算法,适用于已排序或部分有序的数据结构,其时间复杂度为 \(O(\log n)\)。

2. **条件判断与边界处理**:
    - 在解决问题时,要精确判断和处理边界条件。例如,判断旋转的分界点,以及在二分搜索过程中更新 left 和 right 指针的位置。

3. **算法设计思维**:
    - 通过分析问题,识别可以利用的模式(如有序、旋转等),并设计出解决问题的算法。这是解决类似问题的基础。

4. **代码的简洁与清晰**:
    - 良好的代码结构和清晰的逻辑对于解决问题和后续的代码维护是非常重要的。例如,通过循环和条件判断来清晰地展现二分搜索的逻辑。

5. **问题分析与解决策略**:
    - 在面对问题时,先进行分析,理解问题的需求和约束条件,然后再制定解决策略。例如,分析旋转数组的特点,然后选择二分搜索作为解决策略。

6. **测试与验证**:
    - 在实现算法后,通过多组测试用例来验证算法的正确性和完整性是非常重要的。

7. **多语言实现**:
    - 通过尝试在多种编程语言(如 C、C++、Java 等)中实现同一个算法,可以增强对编程语言和算法的理解。

通过解决这类问题,你可以练习和加深对算法和数据结构的理解,提升解决实际编程问题的能力。

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

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

相关文章

crypto:rsarsa

题目 下载压缩包后得到提示文本 根据提示文本信息&#xff0c;我们知道p q e c&#xff0c;可以求出n、φ(n)、d&#xff0c;进而求出m import gmpy2p 964842302901051567659055174001042653494573763923573980064398935203985250729849139956103500916342705037010757073363…

数据结构之堆排序和前,中,后,层序遍历,链式二叉树

首先我们要知道升序我们要建小堆&#xff0c;降序建大堆&#xff0c;这与我们的大多人直觉相违背。 因为我们大多数人认为应该将堆顶的数据输出&#xff0c;但如果这样就会导致堆顶出堆以后&#xff0c;堆结构会被破坏&#xff0c;显然我们不能这样。 所有我们反其道而行&…

anzo capital昂首资本:MT4和MT5 EA测试的主要区别

MT4和MT5EA测试仪的主要区别&#xff0c;anzo capital昂首资本认为体现在以下方面&#xff1a; 首先&#xff0c;对于专业模式的测试&#xff0c;MT4所需的时间大约为30分钟&#xff0c;MT5最多需要10分钟&#xff0c;显然MT5效率更高。 在优化方面&#xff0c;MT4对优化建议…

嵌入式养成计划-41----C++ auto--lambda表达式--C++中的数据类型转换--C++标准模板库(STL)--list--C++文件操作

九十九、auto 99.1 概念 C11引入了自动类型推导&#xff0c;和Python不一样&#xff0c;C中的自动类型推导&#xff0c;需要auto关键字来引导比如 &#xff1a;auto a 1.2; 会被编译器自动识别为 a 为 double 类型 99.2 作用 auto修饰变量&#xff0c;可以自动推导变量的数…

PyQt5开发相关

代码来源&#xff1a;cxinping/PyQt5: 《PyQt5快速开发与实战》配套代码 (github.com) 《PyQt5快速开发与实战》 (1)使用气泡提示 import sys from PyQt5.QtWidgets import QWidget, QToolTip, QApplication from PyQt5.QtGui import QFontclass Winform(QWidget):def __ini…

缺少 Google API 密钥,因此 Chromium 的部分功能将无法使用

当前版本&#xff1a;Chromium 114.0.5724.0 (开发者内部版本) &#xff08;32 位&#xff09; 1 使用 chromedriver.exe 驱动打开&#xff0c;则没有&#xff0c;于是查看参数&#xff0c;发现 --test-typewebdriver。 2 将 chrome.exe 发送到桌面&#xff0c;右键--属性--目…

零代码编程:用ChatGPT批量下载podomatic播客RSS页面音频

podomatic播客上的音频&#xff0c;怎么批量下载呢&#xff1f; 以这个播客为例&#xff1a;https://nosycrow.podomatic.com/rss2.xml 右边有一个RSS Feed的黄色图标&#xff0c;点击打开&#xff1a; 可以看到所有的音频和标题&#xff1a; 查看源代码&#xff0c;音频标题…

asp.net酒店管理系统VS开发sqlserver数据库web结构c#编程Microsoft Visual Studio

一、源码特点 asp.net酒店管理系统是一套完善的web设计管理系统&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为vs2010&#xff0c;数据库为sqlserver2008&#xff0c;使用c#语言开发 asp.net 酒店管理系统1 二、功能介绍 …

2023.10.14 关于 synchronized 基本介绍

目录 synchronized 的特性 互斥 理解阻塞等待 可重入 synchronized 的使用 修饰方法 修饰代码块 synchronized 的特性 JVM 称 synchronized 为监视器锁&#xff08;monitor lock&#xff09; 互斥 synchronized 会起到互斥效果某个线程执行到某个对象的 synchronized 中…

解决:PowerDesigne找不到右边表的工具栏

下载压缩包&#xff1a; PowerDesigner16.5压缩包 https://pan.baidu.com/s/1PxGafZUb5kcqSuPnxT4zgA?pwd6nyz http://PowerDesigner16.5压缩包 提取码&#xff1a;6nyz PowerDesigne破解版 找不到右边表的工具栏&#xff1f; 问题&#xff1a;PowerDesigner 快捷工具栏…

【C语言】通讯录的简单实现

通讯录的内容 contect.h #pragma once // 包含头文件 #include <stdio.h> #include <string.h> #include <assert.h> #include <stdlib.h>// 使用枚举常量定义功能 enum Function {quit, // 注意这是逗号&#xff0c;不是分号save,addition,delete,s…

TCP 协议的相关(部分)特性

TCP的报文结构 首部长度&#xff1a; 与UDP不同&#xff0c;TCP没有有描述数据的长度的变量&#xff08;UDP的是UDP长度&#xff09;&#xff0c;但有描述TCP的报头的长度&#xff0c;为什么要和UDP不同呢&#xff1f;其实是UDP的报头长度是固定的&#xff0c;而TCP的报头是“变…

2023-2024-1 for循环-1

7-1 求N分之一序列前N项和 本题要求编写程序&#xff0c;计算序列 1 1/2 1/3 ... 的前N项之和。 输入格式: 输入在一行中给出一个正整数N。 输出格式: 在一行中按照“sum S”的格式输出部分和的值S&#xff0c;精确到小数点后6位。题目保证计算结果不超过双精度范围。…

Golang中gRPC使用及原理探究

文章目录 概述gRPC的优势&#xff1a; 1、gRPC入门1.1 protobuf安装1.2 使用gRPC1.2.1 定义proto文件1.2.2 编译proto文件1.2.3 编写客户端和服务端代码 2、gRPC的通信模式2.1 一元RPC模式2.2 客户端流RPC模式2.3 服务端流RPC模式2.4双向流RPC模式 3、 gRPC的底层原理探究3.1 H…

基于php 进行每半小时钉钉预警

前言 业务场景&#xff1a;监控当前业务当出现并发情况时技术人员可以可以及时处理 使用技术栈&#xff1a; laravelredis 半小时触发一次报警信息实现思路 1、xshell脚本 具体参数就不详细解释了&#xff0c;想要详细了解可以自行百度 curl -H "Content-Type:appl…

10.数学环境排列数学公式

1.\begin{gathered} \begin{gathered} 是 LaTeX 中的数学环境&#xff0c;通常用于排列多行数学公式或方程组&#xff0c;这些公式或方程组需要在某种程度上垂直居中对齐。这个环境通常用于多行公式&#xff0c;与 align 或 eqnarray 不同&#xff0c;它不会自动对齐等号&…

OAuth2.0、和jwt、spring security之间的区别和联系

OAuth2.0的概念 OAuth 2.0开放授权&#xff0c;OAuth 2.0 是一种授权框架&#xff0c;用于授权第三方应用程序访问用户资源&#xff0c;而无需共享用户的凭据。它为用户提供了更好的隐私和安全性&#xff0c;并允许用户对授权进行细粒度的控制&#xff0c;颁发的token是第三方应…

Vue-2.9单页应用程序

单页应用程序&#xff08;SPA-Single Page Application&#xff09; 所有功能在一个html页面上实现 具体示例&#xff1a;网易云音乐https://music.163.com 京东淘宝等是多页面应用 单页VS多页 单页面应用&#xff1a;系统类网站、内部网站、文档类网站、移动端站点 多页面…

蓝桥杯 枚举算法 (c++)

枚举就是根据提出的问题&#xff0c;——列出该问题的所有可能的解&#xff0c;并在逐一列出的过程中&#xff0c;检验每个可能解是否是问题的真正解&#xff0c; 如果是就采纳这个解&#xff0c;如果不是就继续判断下一个。 枚举法一般比较直观&#xff0c;容易理解&#xff0…

python+django医患档案电子病历管理系统7ld2o

本课题使用Python语言进行开发。代码层面的操作主要在PyCharm中进行&#xff0c;将系统所使用到的表以及数据存储到MySQL数据库中&#xff0c;方便对数据进行操作本课题基于WEB的开发平台 1.运行环境&#xff1a;python3.7/python3.8。 2.IDE环境&#xff1a;pycharmmysql5.7; …