IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 2021-07-07 -> 正文阅读

[数据结构与算法]2021-07-07

                                     **关于这几天的复习与学习**

#复习方面
按照学长的要求将一些基础性的知识全部都复习了一遍,也做了一些题,不过基本都是ACWING上的基础题。
##前缀和与差分
###前缀和
前缀和其实就是求一段数组区间内的所有数字之和,只需要当前缀和数组创建出来后,查询一次便只需要O(1)的复杂度,而线性相加则需要O(n)的复杂度,前缀和其实只是一种思想,公式为s[i]=s[i-1]+a[i],(建议数组下标都从1开始)
模板:https://www.acwing.com/problem/content/797/
二维形式:求前缀和矩阵
1.求s[i,j] 公式:s[i][j]=s[i-1][j]+s[i][j-1]-s[i-1][j-1]+a[i][j];
2.给定左上角和右下角坐标(x1,y1)、(x2,y2),求其中矩阵的数值的和
公式:s=s[x2][y2]-s[x1-1][y2]-s[x2][y1-1]+s[x1-1][y1-1];
模板:https://www.acwing.com/problem/content/798/
###差分
差分实质上就是前缀和的逆运算。
1.一维形式:
差分数组:b[i]=a[i]-a[i-1];
查询:b[l]+=c,b[r+1]-=c
模板:添加链接描述
2.二维形式:(二维差分不需要去考虑差分数组的构造)
查询:b[x1][y1]==c;b[x2+1][y1]-=c,b[x1][y2+1]-=c,b[x2+1][y2+1]+=c;
模板:添加链接描述
##动态规划
###多重背包问题
01背包问题的变种,不同与01背包中的每样物品只有一件,多重背包每样物品都有有限个数件,第一个办法就是将多重背包拆分成01背包,如:

for(int i=1;i<=n;i++)
for(int j=0;j<=m;j++)
for(int k=0;k<s[i]&&j>=k*v[i];k++)
 f[i][j] = max(f[i][j], f[i - 1][j - v[i] * k] + w[i] * k);

这样的复杂度是最高的;
二进制优化:
将物品总共所拥有的s[i]件物品用二进制的方法进行包装,使得从1到s[i]件物品中的任意数量都能从一包装好的物品数量中拼凑出来,可减少计算数量。(看题)
添加链接描述
###分组背包问题
三重循环枚举,目前没有好办法;(看题)
添加链接描述
##并查集
并查集说白了就是划分阵营的问题,每个阵营都有一个共同的大哥大,当进行查询操作时便只需要看大哥大是哪一位就可以确定是哪一个阵营,合并也只需要将两个阵营不同的大哥大变成同一个就行。
find()函数(含路径压缩):

int find(int x)
{
    int r=x;
    while(pre[r]!=r)
        r=pre[r];
    int i=x,j;
    while(i!=r)
    {
        j=pre[i];
        pre[i]=r;
        i=j;
    }
    return r;
}

join函数

void join(int x,int y)
{
    int a=find(x);
    int b=find(y);
    if(a!=b)
    {
        pre[a]=b;
    }
}

看题:
添加链接描述
添加链接描述
添加链接描述
#学习方面
##最短路
###朴素Dijkstra
迪杰斯特拉算法(Dijkstra)是由荷兰计算机科学家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法。是从一个顶点到其余各顶点的最短路径算法,解决的是有权图中最短路径问题。迪杰斯特拉算法主要特点是从起始点开始,采用贪心算法的策略,每次遍历到始点距离最近且未访问过的顶点的邻接节点,直到扩展到终点为止。
在这里插入图片描述
实现:

int Dijkstra()
{
    memset(dist,0x3f,sizeof dist);//除1号结点外,其他均初始为无穷大
    dist[1]=0;
    for(int i=0;i<n;i++) //n次迭代,每次寻找不在s中距离最近的点t
    {
        int t=-1;// 便于更新第一个点
        for(int j=1;j<=n;j++)
          if(!st[j]&&(t==-1||dist[j]<dist[t])) t=j;
        st[t]=true;  //将t加到s中
        for(int j=1;j<=n;j++)  //用t更新其他点的距离
          dist[j]=min(dist[j],dist[t]+g[t][j]);
    }
    if(dist[n]==0x3f3f3f3f) return -1; //路径不存在
    else return dist[n];
}

添加链接描述
###堆优化Dijkstra
一般来说堆优化就是利用堆优化查询操作,可以用优先队列将将原本需要O(n)复杂度的查询距离最近的点的操作简化为O(1)(存图可以用链式前向星);时间复杂度为O(mlogn);

int dijkstra()
{
    memset(dist, 0x3f, sizeof(dist));
    dist[0] = 1;
    priority_queue<PII, vector<PII>, greater<PII>> heap; // 定义一个小根堆
    // 这里heap中为什么要存pair呢,首先小根堆是根据距离来排的,所以有一个变量要是距离,其次在从堆中拿出来的时    
    // 候要知道知道这个点是哪个点,不然怎么更新邻接点呢?所以第二个变量要存点。
    heap.push({ 0, 1 }); // 这个顺序不能倒,pair排序时是先根据first,再根据second,这里显然要根据距离排序
    while(heap.size())
    {
        PII k = heap.top(); // 取不在集合S中距离最短的点
        heap.pop();
        int ver = k.second, distance = k.first;

        if(st[ver]) continue;
        st[ver] = true;

        for(int i = h[ver]; i != -1; i = ne[i])
        {
            int j = e[i]; // i只是个下标,e中在存的是i这个下标对应的点。
            if(dist[j] > distance + w[i])
            {
                dist[j] = distance + w[i];
                heap.push({ dist[j], j });
            }
        }
    }
    if(dist[n] == 0x3f3f3f3f) return -1;
    else return dist[n];
}

(看题)添加链接描述

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-07-11 16:51:09  更:2021-07-11 16:53:37 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/8 19:28:25-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码