C语言-4

news2024/10/5 20:17:14

排序算法简介

/*
    学习内容:
        冒泡排序(最基本的排序方法)
        选择排序(冒泡的优化)
        插入排序(在合适的位置插入合适的数据)
*/

/*
    排序分类:
        1.内部排序
            待需要进行排序的数据全部存放到内存中,再进行排序 
        2.外部排序
            在排序过程中,需要对外存进行访问
            待排序的数据数量很大,内存无法全部容纳所有的数据 
*/

冒泡排序

/*
    冒泡排序:
    ---思路分析(以升序为例)
        在一排数据中,将第一个与第二个比较大小
        如果后面的数据比前面的小,就交换它们的位置(冒泡一次)
        然后比较第二个和第三个
        ...
        直到比较第 n-1 个数据和第 n 个
        每一次比较都将较大的一个数据向后移动
        所以第 n 个是最大的
        所以就排好了一个数据(冒泡一趟)
*/

# include <stdio.h>

int main()
{
    // 定义一个无序一维数组
    int arr[] = { 5, 7, 9, 1, 6, 2, 4, 3, 0, 8 };

    // 遍历,打印数组
    printf("数组,排序前:\n");
    for (int i = 0; i < 10; i++)
    {
        printf("%-3d", arr[i]);
    }

    // 冒泡排序(升序:由小到大)
    int temp;
    for (int i = 0; i < 9; i++)
    {
        for (int j = 0; j < 9 - i; j++)
        {
            if (arr[j] > arr[j + 1])
            {
                temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }

    // 展示排序后,数组当前的结果
    printf("数组,排序后:\n");
    for (int i = 0; i < 10; i++)
    {
        printf("%-3d", arr[i]);
    }

}

选择排序

/*
    选择排序:
    ---思路分析(以升序为例)
            选择排序可以看作是冒泡排序的优化
        不再多次交换值,而是选择当前趟数的最大(或最小值),最后再交换
            在 n 个数里,先找到最大的数,并且记录下标,然后将这个数与第 n 个数交换
        如果第 n 个数是最大的,那就不需要交换,重复比较,直到所有的数据排好序
*/

# include <stdio.h>

int main()
{
    // 定义一个无序一维数组
    int arr[] = { 5, 7, 9, 1, 6, 2, 4, 3, 0, 8 };


    // 遍历,打印数组
    printf("\n 数组,排序前:\n");
    for (int i = 0; i < 10; i++)
    {
        printf("%-3d", arr[i]);
    }


    // 选择排序(升序:由小到大)---> 选择排序:选择一个你认为最大的数
    int temp;
    int maxIndex;
    for (int i = 9; i > 0; i--)
    {
        maxIndex = 0;    // 每次我都认为第一个最大,选择第一个,并记录下第一个的序号
        for (int j = 0; j <= i; j++)
        {
            if (arr[maxIndex] < arr[j])
            {
                maxIndex = j;
            }
        }

        if (maxIndex != i)
        {
            temp = arr[i];
            arr[i] = arr[maxIndex];
            arr[maxIndex] = temp;
        }

    }
    

    // 展示排序后,数组当前的结果
    printf("\n 数组,排序后:\n");
    for (int i = 0; i < 10; i++)
    {
        printf("%-3d", arr[i]);
    }

}

插入排序

/*
    插入排序:
    ---思路分析(以升序为例)
        以第一个数为基准,后面的所有数都向着第一个数的方向,插队前进(这种插队不能跳着插队,只能插完一个继续接着插,前提是满足条件才能插队)
        其本质原理:依靠数与数之间的“相对关系”,从而将其整体排好序!

            1.轮到第一个数发挥            第一个数无法插队,它只能站着不动,停止插队
            2.轮到第二个数发挥            它和前面的数比较大小,若满足条件,则插一个队,然后停止插队(即:最多能够插队1次)
            3.轮到第三个数发挥            和前面的数比较大小,若满足条件,则插一个队,再继续和前面的数比较大小,若满足条件,则再插一个队,然后停止插队(即:最多能够插队2次)
            4.轮到第四个数发挥            比较大小,若可以,插一个队,再继续比较大小,若可以,再插一个队......(即:最多能够插队3次)
            5.轮到第五个数发挥            ......(即:最多能够插队4次)
            6.轮到第六个数发挥            ......(即:最多能够插队5次)

*/

# include <stdio.h>

int main()
{
    // 定义一个无序一维数组
    int arr[] = { 7, 5, 9, 1, 6, 2, 4, 3, 0, 8 };


    // 遍历,打印数组
    printf("\n 数组,排序前:\n");
    for (int i = 0; i < 10; i++)
    {
        printf("%-3d", arr[i]);
    }


    // 插入排序(升序:由小到大) 
    int temp = 0;
    for (int i = 1; i < 10; i++)    // 轮到第 ?个数发挥
    {

        for (int j = i - 1; j >= 0; j--)    // 【比较、插队】,再【比较、插队】,再再【比较、插队】......
        {
            if (arr[j + 1] < arr[j])    // 满足插队条件
            {
                temp = arr[j + 1];
                arr[j + 1] = arr[j];
                arr[j] = temp;
            }
            else   // 不满足插队条件
            {
                break;        // 没有达到"最多能插队的次数",就停止插队了,请马上自我了断,不要再进行无意义的比较,从而提高效率
            }
        }

    }


    // 展示排序后,数组当前的结果
    printf("\n 数组,排序后:\n");
    for (int i = 0; i < 10; i++)
    {
        printf("%-3d", arr[i]);
    }

    return 0;
}

线性表

/*
    1.线性表:
       ---数据结构中最简单的一种存储结构,专门用于存储逻辑关系为"一对一"的数据 

    2.线性表存储结构,可细分为"顺序存储结构"和"链式存储结构",即如下所示
        线性表:
            1.顺序表(顺序存储结构)
            2.链表(链式存储结构)

    3.存储的类型要求
        使用线性表存储的数据,如同向数组中存储数据那样要求数据类型必须一致
        线性表存储的数据,要么全部都是整型,要么全部都是字符串
        一半整型,另一半是字符串的一组数据无法使用线性表存储

    4.前驱与后继:
        一组数据中的每个个体被称为“数据元素”(简称为“元素”)
            1.前驱
                某一元素的左侧相邻元素称为“直接前驱”,位于此元素左侧的所有元素都统称为“前驱元素”
            2.后继
                某一元素的后侧相邻元素称为“直接后继”,位于此元素右侧的所有元素都统称为“后继元素”
*/

在这里插入图片描述
在这里插入图片描述

顺序表

/*
    顺序表:
    ---它对数据的物理存储结构有要求
       顺序表存储数据时,会提前申请一块足够大小的内存
       然后将数据依次存储起来
       存储时做到数据元素之间不留一丝缝隙(即:连续)

*/

初始化顺序表

# include <stdio.h>
# include <malloc.h>


// 定义表格类型
typedef struct
{
    int* head;        // 指针,存储申请的内存首地址
    int length;        // 当前数据个数
    int size;        // 元素个数(最大容量)

}Table;


// 生成表格的函数
Table tableFunc()
{
    Table t;        // 定义一个变量 t ,其类型为“表格类型”
    // t 表格的初始化
    t.size = 5;                                // 表格最大容量(元素个数) = 5
    t.length = 0;                            // 表格当前数据个数(元素个数)= 0
    t.head = (int*)calloc(t.size,sizeof(int));    // 为表格开辟内存,并把内存首地址赋值给 t.head
    // 注意!上面的申请内存操作可能会出现申请失败的情况,返回值为 NULL
    if (!NULL)
    {
        printf("申请内存失败,程序终止!\n");
        exit(0);
    }
    
    return t;    // 返回 t 表格
}


int main()
{
    Table myTab = tableFunc();

    printf("%d \n", myTab.size);
    printf("%d \n", myTab.length);
    printf("%X \n", myTab.head);    // 内存地址一般用 %X 十六进制展示


    return 0;
}

顺序表的增删查改

/*
    顺序表元素:
    1.查(可以使用查找算法:  1.顺序查找    2.二分法查找)
    2.改
    3.增(增加到前面、中间、后面)------知识点补充:扩容函数:realloc(需要扩容的指针"*p",扩容后总的大小)
    4.删
*/

链表

/*
    1.链表:
        1.链表是通过指针,将不连续的内存连接起来,实现链式存储的

        2.内存实际上是不同时机申请的,地址不一定连续,但是可以通过指针联系起来

        3.链表是数据结构中线性表的一种,其中的每个元素实际上是一个“单独的结构体变量”,
        所有变量都“通过”每个元素中的“指针”连接在一起。

        4.以结构体为节点,将一个结构体看成“数据域”和“指针域”两个部分,
        “数据域”用于“存储数据”,“指针域”用于“连接下一个节点”,链表中每个结构体对象叫做节点,
        其中,第一个数据节点,叫做链表的“首元结点”。

        5.如果第一个节点不用于存储数据,只用于代表链表的起始点,则这个结点称为链表的“头结点”。
        

    2.链表特点:
        1.没有固定长度
        2.可以快速的插入和删除链表中的节点

    
    3.链表分很多种,单链表是其中最简单的一种(如下图)

*/

在这里插入图片描述

单链表

/*
    <单链表>

    1.链表节点一般是自定义的结构体类型

    2.结构体一般包含两部分:数据、指针
        数据:当前节点里面需要的数据
        指针:指向下一个节点(最后一个节点置空 为“尾节点”) 

*/

在这里插入图片描述

创建单链表

  • 项目结构
    在这里插入图片描述

  • 源代码

// main.c

# include <stdio.h>
# include "myList.h"

int main()
{
    Node* pList=CreateList(5);    // 创建一个可以存储5个东西的链表,并将返回值“地址”赋值给变量 pList
    showList(pList);    // 展示链表
    return 0;
}
// myList.c

# include <stdio.h>
# include "myList.h"
# include <stdlib.h>    // 申请内存时候要用

/*
创建链表
参    数:长度
返回值:头指针
*/
Node* CreateList(int length)
{
    // 判断长度
    if (length <= 0)
    {
        printf("Length Error!\n");
        return NULL;
    }

    // 开始创建链表

    // 1.创建头指针和尾指针
    Node *phead, *ptail;
    phead = ptail = NULL;

    // 2.申请内存:头结点
    phead = (Node*)malloc(sizeof(Node));

    // 3.处理异常情况
    if (NULL == phead)
    {
        perror("malloc failed!");
        exit(EXIT_FAILURE);
    }

    // 4.给头结点初值
    phead->pnext = NULL;    // 等价于 (*phead).pnext = NULL;
    phead->num = 0;

    // 5.尾指针
    ptail = phead;

    // 6.向头结点后面添加结点
    Node* p;
    DataType n;
    for (int i = 0; i < length; i++)
    {
        // 6.1 申请一个结点,检测,给值
         p= (Node*)malloc(sizeof(Node));
         if (NULL == p)
         {
             perror("malloc failed!");
             exit(EXIT_FAILURE);
         }
         p->pnext = NULL;
         printf("请输入数值>>>");
         scanf("%d", &n);
         p->num = n;

         // 6.2 将新申请的结点添加到链表中
         ptail->pnext = p;
         ptail = p;        // 更新尾结点
    }


    return phead;    // 9.返回头指针
}



/*
遍历链表
参    数:头指针
返回值:空
*/
void showList(const Node* const p)
{
    // 从首元结点开始遍历,而不是头结点(因为我们不使用头结点去存储值)
    Node* temp = p->pnext;
    if (NULL == temp)
    {
        printf("List is NULL!\n");
        return ;
    }
    printf("\n*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
    printf("当前链表数据:\n");
    while (temp)
    {
        printf("%-5d", temp->num);
        temp = temp->pnext;
    }
    printf("\n*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
}
// myList.h

#ifndef _MYLIST_    // 防止重复定义
#define    _MYLIST_

typedef int DataType;    // 可以灵活改变数据类型

struct node
{
    struct node* pnext;        // 指针域
    DataType num;            // 数据域
};

typedef struct node Node;    // 给结构体类型取别名



/*
    创建链表
    参    数:长度
    返回值:头指针
*/
Node* CreateList(int length);



/*
    遍历链表
    参    数:头指针
    返回值:空
*/
void showList(const Node* const p);



#endif    // _MYLIST_ 定义结束

单链表的查改增删

/*
    单链表的查、改、增、删
        1.查:确定查找方式,查找之后一般会返回“结点首地址”或者返回 NULL
        2.改:找到目标元素,直接修改该元素的值
        3.增:一定注意不能丢失指针指向
        4.删:记得释放内存

*/

/*
    栈的定义:
    ---栈是一种只能从表的一端存储数据,且遵循“先进后出”原则的"线性存储结构"
        1.栈只能从一端(栈顶)取出,另一端(栈底)是封闭的
        2.在栈中,都必须从“栈顶”存储数据,且遵循“先进后出”原则

    
    入栈和出栈:
        1.入栈:将数据存到栈里面去 
        2.出栈:将数据从站里面取出来


    栈的实现方法:
    ---栈:“特殊”的线性存储结构
        1.顺序表:顺序栈(顺序存储结构)
        2.链  表:链  栈(链式存储结构)

*/

在这里插入图片描述

实现顺序栈

# include <stdio.h>

/* 1.元素入栈 */
// 参  数:存储结构,栈顶 top,数据 value
// 返回值: top
int putEle(int* arr, int top, int value)
{
    arr[++top] = value;
    return top;
}

/* 2.元素入栈 */
// 参  数:存储结构,栈顶 top
// 返回值: top
int takeEle(int* arr, int top)
{
    // 先判断
    if (top <= -1)
    {
        printf("操作失败!空栈!\n");
        return -1;
    }
    printf("当前出栈元素的值:%d\n", arr[top]);
    top--;
    return top;
}

int main()
{
    // 顺序表:为了理解简单化,我们使用列表
    int a[100];

    // top (记录栈顶)
    int top = -1;

    // 入栈(入5个)
    top = putEle(a, top, 1);
    top = putEle(a, top, 2);
    top = putEle(a, top, 3);
    top = putEle(a, top, 4);
    top = putEle(a, top, 5);

    // 出栈(出6个)
    top = takeEle(a, top);
    top = takeEle(a, top);
    top = takeEle(a, top);
    top = takeEle(a, top);
    top = takeEle(a, top);
    top = takeEle(a, top);

    return 0;
}

实现链栈

/*
    链栈:
        一般来说,我们将链表的“头结点”作为栈顶,“尾结点”作为栈底,这样的效率高一些(如图所示)

    注意事项:
        “头结点”是不断更新的,即“头结点”永远是“刚进来”的那个
        “尾结点”是不会更新的,即“尾结点”永远是“第一个进来”的那个

    ---如果用另外一种方式:
        头结点”作为栈底,“尾结点”作为栈顶,这种方式,每次新的元素入栈,都要从栈底遍历一遍到栈顶,才能入栈成功
        将会遍历很多次,效率非常低下
*/

在这里插入图片描述

#include <stdio.h>
#include <stdlib.h>

typedef struct Node
{
    int data;
    struct Node* pnext;

}Node;


// 入栈函数
Node* eleIn(Node* p, int num)
{
    Node* temp = (Node*)malloc(sizeof(Node));
    temp->data = num;
    temp->pnext = p;
    p=temp;
    printf("当前进栈元素的值:%d\n", num);
    return p;
}


// 出栈函数
Node* eleOut(Node* p)
{
    if (p)
    {
        Node* temp = p;
        printf("当前出栈元素的值:%d\n", temp->data);
        p = temp->pnext;
        free(temp);
        temp = NULL;
    }
    else
    {
        printf("栈是空的!\n");
    }

    return p;
}



int main()
{
    Node* p = NULL;

    // 进栈(5次)
    p = eleIn(p, 1);
    p = eleIn(p, 2);
    p = eleIn(p, 3);
    p = eleIn(p, 4);
    p = eleIn(p, 5);

    printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");

    // 出栈(6次)
    p = eleOut(p);
    p = eleOut(p);
    p = eleOut(p);
    p = eleOut(p);
    p = eleOut(p);
    p = eleOut(p);

    return 0;
}

队列

/*
    <队列>

    1. 什么是队列
        队列:两端“开口”
        要求:只能从一端进入队列,另一端出队列

    2.队头和队尾
        队头:数据出队列的一端
        队尾:数据进队列的一端 

    3.实现队列
        1.顺序表:顺序队列
        2.链表:链式队列

*/

在这里插入图片描述

顺序队列

在这里插入图片描述

#include <stdio.h>


// 进队函数
int eleIn(int* arr,int tail,int num)
{
    arr[++tail] = num;
    printf("当前进入队列元素的值:%d\n", num);
    return tail;
}


// 出队(全部出队)
void allOut(int* arr, int head, int tail)
{
    while (head != tail)
    {
        printf("当前离开队列元素的值:%d\n", arr[head++]);
    }
    printf("当前离开队列元素的值:%d\n", arr[head++]);
}



int main()
{
    int a[10];    // 定义数组,用于存储数据
    int head = 0;
    int tail = -1;

    // 入队(进入5)
    tail = eleIn(a, tail, 1);
    tail = eleIn(a, tail, 2);
    tail = eleIn(a, tail, 3);
    tail = eleIn(a, tail, 4);
    tail = eleIn(a, tail, 5);

    printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");

    // 出队(全出去)
    allOut(a, head, tail);

    return 0;
}

链式队列

#include <stdio.h>
#include <stdlib.h>


// 创建结点类型
typedef struct QNode
{
    int data;
    struct QNode* pnext;
}QNode;


// 生成“头结点”的函数
createQueue()
{
    QNode* temp = (QNode*)malloc(sizeof(QNode));
    temp->data = 0;
    temp->pnext = NULL;
    return temp;
}


// 入队
eleIn(QNode* p, int num)    // 参数:(尾指针,要存储的数据)
{
    QNode* temp = (QNode*)malloc(sizeof(QNode));
    temp->data = num;
    printf("当前进入队列元素的值:%d\n", num);
    temp->pnext = NULL;
    p->pnext = temp;
    p = temp;
    
    return p ;
}


// 出队
void eleOut(QNode* phead)
{
    if (phead->pnext)    // “头结点”存储的地址不为空
    {
        QNode* temp = phead->pnext;    // “头结点”后面的首元结点
        printf("当前离开队列元素的值:%d\n", temp->data);
        phead->pnext = temp->pnext;
        free(temp);
        temp = NULL;
    }
    else
    {
        printf("队列为空!\n");
    }

    // return ;
}


int main()
{
    // 头指针和尾指针
    QNode* phead = NULL;
    QNode* ptail = NULL;
    
    // “上面的两针”都指向生成的“头结点”
    phead = ptail = createQueue();

    // 入队(进入5)
    ptail = eleIn(ptail, 1);
    ptail = eleIn(ptail, 2);
    ptail = eleIn(ptail, 3);
    ptail = eleIn(ptail, 4);
    ptail = eleIn(ptail, 5);

    printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");

    // 出队(出去6)
    eleOut(phead);
    eleOut(phead);
    eleOut(phead);
    eleOut(phead);
    eleOut(phead);
    eleOut(phead);

    return 0;
}

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

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

相关文章

【Python基础】案例分析:电商分析

电商分析 1 案例:某年淘宝双12部分购物数据 1.1 数据&#xff1a;某年淘宝双12部分购物数据&#xff1b; 来源&#xff1a;天池数据平台 1.2 分析目的&#xff1a; 熟悉电商常用分析指标用户行为分析用户价值模型 2 熟悉数据 2.1 导入数据 import pandas as pd fpath …

Vscode编译运行多个C++文件

1.摘要 在使用Vscode编译单个文件网上很多教程&#xff0c;但是对多个文件编译会发现经常出问题&#xff0c;通过不断的借阅网友的教程改进终于完成C运行多个文件教程如下&#xff1a; 2.编译运行过程 2.1 初始配置过程 &#xff08;1&#xff09;Vscode以及MinGW配置教程很…

EasyRecovery数据恢复软件2024最新特别绿色版下载

EasyRecovery数据恢复软件是一款功能强大的工具&#xff0c;最新版本通常包含更多优化和新增功能&#xff0c;以提升用户体验和数据恢复成功率。由于软件版本会不断更新&#xff0c;我无法提供特定于最新版本的详细介绍&#xff0c;但我可以概述EasyRecovery的一般功能以及下载…

20240206在WIN10下下载安装RX580的驱动程序

20240206在WIN10下下载安装RX580的驱动程序 2024/2/6 19:24 百度搜索&#xff1a;RX580 驱动 我用的是X99主板的渲染服务器&#xff0c;只能装WIN10的64位系统。直接下载并安装最新的驱动程序就可以了&#xff01; 另&#xff1a;我以前的电脑插的是RX550的显卡&#xff0c;直接…

推动海外云手机发展的几个因素

随着科技的不断发展&#xff0c;海外云手机作为一种新兴技术&#xff0c;在未来呈现出令人瞩目的发展趋势。本文将在用户需求、技术创新和全球市场前景等方面&#xff0c;探讨海外云手机在未来的发展。 1. 用户需求的引领&#xff1a; 随着人们对移动性和便捷性的需求不断增长&…

【数据结构和算法】--- 基于c语言排序算法的实现(1)

目录 一、排序的概念及其应用1.1排序的概念1.2 排序的应用1.3 常见的排序算法 二、插入排序2.1直接插入排序2.2 希尔排序2.2.1 预排序2.2.2 缩小gap2.2.3 小结 三、选择排序3.1 直接选择排序3.2 堆排序 一、排序的概念及其应用 1.1排序的概念 排序&#xff1a; 所谓排序&…

R语言 Error in make.names(col.names, unique = TRUE) : invalid multibyte string at ‘<b1><ea><cc><e2>‘

R语言导入CSV文件的时候&#xff0c;代码如下&#xff1a; data<-read.csv("data.csv") 出现以下报错&#xff1a; Error in make.names(col.names, unique TRUE) : invalid multibyte string at <b1><ea><cc><e2> Error in make.n…

LeetCode、17. 电话号码的字母组合【中等,dfs回溯】

文章目录 前言LeetCode、17. 电话号码的字母组合【中等&#xff0c;dfs回溯】题目与类型思路递归回溯优化&#xff1a;StringBuilder来回溯补充代码&#xff1a;2024.1.31&#xff08;简化&#xff09; 资料获取 前言 博主介绍&#xff1a;✌目前全网粉丝2W&#xff0c;csdn博…

Transformer实战-系列教程6:Vision Transformer 源码解读4

&#x1f6a9;&#x1f6a9;&#x1f6a9;Transformer实战-系列教程总目录 有任何问题欢迎在下面留言 本篇文章的代码运行界面均在Pycharm中进行 本篇文章配套的代码资源已经上传 Vision Transformer 源码解读1 Vision Transformer 源码解读2 Vision Transformer 源码解读3 Vis…

mac检查CPU温度和风扇速度软件:Macs Fan Control Pro 1.5.17中文版

Macs Fan Control Pro for Mac是一款专业的电脑风扇控制工具&#xff0c;旨在帮助Mac用户有效控制电脑的风扇速度&#xff0c;提高电脑的运行效率和稳定性。 软件下载&#xff1a;Macs Fan Control Pro 1.5.17中文版 该软件支持多种风扇控制模式和预设方案&#xff0c;用户可以…

【leetcode】206. 反转链表(简单)题解学习

题目描述&#xff1a; 给你单链表的头节点 head &#xff0c;请你反转链表&#xff0c;并返回反转后的链表。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5] 输出&#xff1a;[5,4,3,2,1]示例 2&#xff1a; 输入&#xff1a;head [1,2] 输出&#xff1a;[2,1]示例 …

VLM 系列——Llava1.6——论文解读

一、概述 1、是什么 Llava1.6 是llava1.5 的升级暂时还没有论文等&#xff0c;是一个多模态视觉-文本大语言模型&#xff0c;可以完成&#xff1a;图像描述、视觉问答、根据图片写代码&#xff08;HTML、JS、CSS&#xff09;&#xff0c;潜在可以完成单个目标的视觉定位、名画…

【JavaScript 漫游】【006】数据类型 array

文章简介 本文为【JavaScript 漫游】专栏的第 006 篇文章&#xff0c;记录笔者在了解 JS 数据类型 array 中摘录的知识点。 数组的本质是对象属组的 length 属性for ... in 循环和数组的遍历数组的空位类数组对象 除了上述 5 个重要知识点&#xff0c;学习数组更为重要的是掌…

MySQL组复制的介绍

前言 本文介绍关于MySQL组复制的背景信息和基本原理。包括&#xff0c;介绍MySQL传统复制方法的原理和隐患、介绍组复制的原理&#xff0c;单主模式和多主模式等等。通过结合原理图学习这些概念&#xff0c;可以很好的帮助我们理解组复制技术这一MySQL高可用方案&#xff0c;有…

Linux系统中安装JDK

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…

深入探究:JSONCPP库的使用与原理解析

君子不器 &#x1f680;JsonCPP开源项目直达链接 文章目录 简介Json示例小结 JsoncppJson::Value序列化Json::Writer 类Json::FastWriter 类Json::StyledWriter 类Json::StreamWriter 类Json::StreamWriterBuilder 类示例 反序列化Json::Reader 类Json::CharReader 类Json::Ch…

VScode上无法运行TSC命令,Typescript

如何解决问题 第一步&#xff1a;使用 winx 快捷键&#xff0c;会出现如下弹窗&#xff0c;鼠标左键单击Windows PowerShell 即可打开shell 第二步&#xff1a;运行 set-ExecutionPolicy RemoteSigned 命令&#xff0c;在询问更改执行策略的时候选择敲Y或者A 第三步&#xff…

python_蓝桥杯刷题记录_笔记_全AC代码_入门5

前言 关于入门地刷题到现在就结束了。 题单目录 1.P1579 哥德巴赫猜想&#xff08;升级版&#xff09; 2.P1426 小鱼会有危险吗 1.P1579 哥德巴赫猜想&#xff08;升级版&#xff09; 一开始写的代码是三重循环&#xff0c;结果提交上去一堆地TLE&#xff0c;然后我就给减少…

数据库学习案例20240206-ORACLE NEW RAC agent and resource关系汇总。

1 集群架构图 整体集群架构图如下&#xff1a; 1 数据库启动顺序OHASD层面 操作系统进程init.ohasd run启动ohasd.bin init.ohasd run 集群自动启动是否被禁用 crsctl enable has/crsGIHOME所在文件系统是否被正常挂载。管道文件npohasd是否能够被访问&#xff0c; cd /var/t…

Etsy做什么店铺比较靠谱? 什么叫做真人店?

作为Etsy是美国最大的原创手工在线销售平台之一&#xff0c;以其店铺利润高、平台佣金低、平台同质化不严重的优点在跨境电商里颇具竞争力。然而Etsy开店却不是件容易事&#xff0c;原因是Etsy真人店对于环境以及卖家的运营操作要求较高&#xff0c;下面就给各位有意入局Etsy的…