imgaug库指南(28):从入门到精通的【图像增强】之旅(万字长文)

news2025/1/17 18:09:36

引言

在深度学习和计算机视觉的世界里,数据是模型训练的基石,其质量与数量直接影响着模型的性能。然而,获取大量高质量的标注数据往往需要耗费大量的时间和资源。正因如此,数据增强技术应运而生,成为了解决这一问题的关键所在。而imgaug,作为一个功能强大的图像增强库,为我们提供了简便且高效的方法来扩充数据集。本系列博客将带您深入了解如何运用imgaug进行图像增强,助您在深度学习的道路上更进一步。我们将从基础概念讲起,逐步引导您掌握各种变换方法,以及如何根据实际需求定制变换序列。让我们一起深入了解这个强大的工具,探索更多可能性,共同推动深度学习的发展。


前期回顾

链接主要内容
imgaug库指南(11):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— 加性高斯噪声(AdditiveGaussianNoise方法)
imgaug库指南(12):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— 加性拉普拉斯噪声(AdditiveLaplaceNoise方法)
imgaug库指南(13):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— 加性泊松噪声(AdditivePoissonNoise方法)
imgaug库指南(14):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— 乘法运算(Multiply方法)
imgaug库指南(15):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— 乘法运算(MultiplyElementwise方法)
imgaug库指南(16):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— Cutout方法
imgaug库指南(17):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— Dropout方法
imgaug库指南(18):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— CoarseDropout方法
imgaug库指南(19):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— Dropout2D方法
imgaug库指南(20):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— TotalDropout方法
imgaug库指南(21):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— ReplaceElementwise方法
imgaug库指南(22):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— ImpulseNoise方法
imgaug库指南(23):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— SaltAndPepper方法
imgaug库指南(24):从入门到精通的【图像增强】之旅(干货!万字长文!)详细介绍了imgaug库的数据增强方法 —— CoarseSaltAndPepper方法

在本博客中,我们将向您详细介绍imgaug库的数据增强方法 —— CoarsePepper方法


CoarsePepper方法

功能介绍

iaa.CoarsePepperimgaug库中另一个用于添加黑椒噪声的方法。与iaa.Pepper相比,iaa.CoarsePepper添加的噪声颗粒更大,通常用于模拟较为粗糙的噪声模式。以下是三个具体的使用场景举例:

  1. 图像分割和目标检测任务:在这些任务中,iaa.CoarsePepper可以帮助模拟图像中的粗糙噪声模式,从而使得模型在训练过程中更加鲁棒。通过将这种噪声模式添加到训练数据中,模型将学会在面对类似噪声的输入时更好地处理和识别目标。
  2. 图像修复和增强任务:在图像修复和增强的应用中,iaa.CoarsePepper可以用来模拟图像中可能存在的较大噪声区域。通过将这种噪声模式添加到图像中,然后使用适当的算法进行修复或增强,可以训练出更强大的图像处理系统。
  3. 深度学习模型的预处理阶段:在使用深度学习模型进行图像处理之前,通常需要进行数据预处理。iaa.CoarsePepper可以用于这一阶段,以增加训练数据的多样性,并帮助模型更好地泛化到实际应用中可能遇到的噪声模式。通过在训练过程中引入这种噪声模式,模型将学会更好地处理实际应用中的噪声问题。

语法

import imgaug.augmenters as iaa
aug = iaa.CoarsePepper(p=(0.02, 0.1), size_px=None, size_percent=None, per_channel=False, min_size=3, seed=None, name=None, random_state='deprecated', deterministic='deprecated')

以下是对iaa.CoarsePepper方法中各个参数的详细介绍:

  1. p

    • 类型:可以是浮点数|浮点数元组|浮点数列表。
    • 描述:将像素替换为黑椒噪声的概率。
      • p为浮点数,则表示将像素替换为黑椒噪声的概率;
      • p为元组(a, b),则将像素替换为黑椒噪声的概率为从区间[a, b]中采样的随机数;
      • p为列表,则将像素替换为黑椒噪声的概率为从列表中随机采样的浮点数;
  2. size_px:

    • 类型:可以是整数|整数元组|整数列表。
    • 描述:定义每个噪声方块的大小。
      • size_px为整数,例如size_px为3,且RGB图像的宽和高都为300。则每个噪声方块大小为(H/size_px, W/size_px), 即(100, 100) ==> 将RGB图像分成9宫格, 每个宫格形状(100, 100), 根据参数p的大小确定有多少个宫格会被替换为黑椒噪声方块;
      • size_px为元组(a, b),则每个噪声方块大小为(H/size, W/size), size为从区间[a, b]中采样的随机数;
      • size_px为列表,则每个噪声方块大小为(H/size, W/size), size为从列表中随机采样的数;
    • 注意:若size_pxNone,则size_percent参数必须设置。
  3. size_percent:

    • 类型:可以是浮点数|浮点数元组|浮点数列表。
    • 描述:定义每个噪声方块的大小。
      • size_percent为浮点数0.02,则每个噪声方块大小为(1/size_percent, 1/size_percent), 即(50, 50);
      • size_percent为元组(a, b),则每个噪声方块大小为(1/size, 1/size), size为从区间[a, b]中采样的随机数;
      • size_percent为列表,则每个噪声方块大小为(1/size, 1/size), size为从列表中随机采样的数;
    • 注意:若size_percentNone,则size_px参数必须设置。
  4. per_channel:

    • 类型:布尔值(TrueFalse)|浮点数。
    • 描述
      • per_channelTrue,则RGB图像的每个像素位置所对应的三个通道像素值可能不会同时替换为黑椒噪声方块 ==> RGB图像会出现彩色失真;
      • per_channelFalse,则RGB图像的每个像素位置所对应的三个通道像素值会同时替换为黑椒噪声方块;
      • per_channel为区间[0,1]的浮点数,假设per_channel=0.6,那么对于60%的图像,per_channelTrue;对于剩余的40%的图像,per_channelFalse
  5. min_size:

    • 类型:整数
    • 描述:考虑到错误地设置size_percentsize_px参数会导致整个图像都被替换成黑椒噪声,因此通过设置min_size来确保最大的噪声方块不至于太大。
  6. seed:

    • 类型:整数|None
    • 描述:用于设置随机数生成器的种子。如果提供了种子,则结果将是可重复的。默认值为None,表示随机数生成器将使用随机种子。
  7. name:

    • 类型:字符串或None
    • 描述:用于标识增强器的名称。如果提供了名称,则可以在日志和可视化中识别该增强器。默认值为None,表示增强器将没有名称。

示例代码

  1. 使用不同的p
import cv2
import imgaug.augmenters as iaa
import matplotlib.pyplot as plt

# 读取图像
img_path = r"D:\python_project\lena.png"
img = cv2.imread(img_path)
image = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)

# 创建数据增强器
aug1 = iaa.CoarsePepper(p=0.2, size_px=3, size_percent=None, per_channel=False, min_size=3, seed=0)
aug2 = iaa.CoarsePepper(p=0.5, size_px=3, size_percent=None, per_channel=False, min_size=3, seed=0)
aug3 = iaa.CoarsePepper(p=0.8, size_px=3, size_percent=None, per_channel=False, min_size=3, seed=0)

# 对图像进行数据增强
Augmented_image1 = aug1(image=image)
Augmented_image2 = aug2(image=image)
Augmented_image3 = aug3(image=image)

# 展示原始图像和数据增强后的图像
fig, axes = plt.subplots(2, 2, figsize=(10, 10))
axes[0][0].imshow(image)
axes[0][0].set_title("Original Image")
axes[0][1].imshow(Augmented_image1)
axes[0][1].set_title("Augmented Image1")
axes[1][0].imshow(Augmented_image2)
axes[1][0].set_title("Augmented Image2")
axes[1][1].imshow(Augmented_image3)
axes[1][1].set_title("Augmented Image3")
plt.show()

运行结果如下:

图1 原图及数据增强结果可视化(使用不同的p参数)

可以从图1看到:

  • p参数设置的越接近1.0时,图像增强后的新图像将会出现更多的黑椒噪声方块。
  • 由于size_px为3,且RGB图像的宽和高都接近300,因此每个黑椒噪声方块的尺寸都接近(100, 100) ==> 先把RGB图像分为9宫格,即9个相同大小的区域,再根据参数p确定将多少个区域替换为黑椒噪声方块。
  1. 使用不同的size_px
import cv2
import imgaug.augmenters as iaa
import matplotlib.pyplot as plt

# 读取图像
img_path = r"D:\python_project\lena.png"
img = cv2.imread(img_path)
image = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)

# 创建数据增强器
aug1 = iaa.CoarsePepper(p=0.5, size_px=3, size_percent=None, per_channel=False, min_size=3, seed=0)
aug2 = iaa.CoarsePepper(p=0.5, size_px=6, size_percent=None, per_channel=False, min_size=3, seed=0)
aug3 = iaa.CoarsePepper(p=0.5, size_px=10, size_percent=None, per_channel=False, min_size=3, seed=0)

# 对图像进行数据增强
Augmented_image1 = aug1(image=image)
Augmented_image2 = aug2(image=image)
Augmented_image3 = aug3(image=image)

# 展示原始图像和数据增强后的图像
fig, axes = plt.subplots(2, 2, figsize=(10, 10))
axes[0][0].imshow(image)
axes[0][0].set_title("Original Image")
axes[0][1].imshow(Augmented_image1)
axes[0][1].set_title("Augmented Image1")
axes[1][0].imshow(Augmented_image2)
axes[1][0].set_title("Augmented Image2")
axes[1][1].imshow(Augmented_image3)
axes[1][1].set_title("Augmented Image3")
plt.show()

运行结果如下:

图2 原图及数据增强结果可视化(使用不同的size_px参数)

可以从图2看到:

  • size_px参数设置的越大时,增强后的新图像的每个黑椒噪声方块的尺寸会越小。
    • size_px=3时,由于RGB图像的宽和高都接近300,因此每个黑椒噪声方块的尺寸都接近(100, 100) ==> 先把RGB图像分为9宫格,即9个相同大小的区域,再根据参数p确定将多少个区域替换为黑椒噪声方块。
    • size_px=6时,由于RGB图像的宽和高都接近300,因此每个黑椒噪声方块的尺寸都接近(50, 50) ==> 先把RGB图像分为36宫格,即36个相同大小的区域,再根据参数p确定将多少个区域替换为黑椒噪声方块。
    • size_px=10时,由于RGB图像的宽和高都接近300,因此每个黑椒噪声方块的尺寸都接近(30, 30) ==> 先把RGB图像分为100宫格,即100个相同大小的区域,再根据参数p确定将多少个区域替换为黑椒噪声方块。
  1. 使用不同的size_percent
import cv2
import imgaug.augmenters as iaa
import matplotlib.pyplot as plt

# 读取图像
img_path = r"D:\python_project\lena.png"
img = cv2.imread(img_path)
image = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)

# 创建数据增强器
aug1 = iaa.CoarsePepper(p=0.5, size_px=None, size_percent=0.02, per_channel=False, min_size=3, seed=0)
aug2 = iaa.CoarsePepper(p=0.5, size_px=None, size_percent=0.05, per_channel=False, min_size=3, seed=0)
aug3 = iaa.CoarsePepper(p=0.5, size_px=None, size_percent=0.1, per_channel=False, min_size=3, seed=0)

# 对图像进行数据增强
Augmented_image1 = aug1(image=image)
Augmented_image2 = aug2(image=image)
Augmented_image3 = aug3(image=image)

# 展示原始图像和数据增强后的图像
fig, axes = plt.subplots(2, 2, figsize=(10, 10))
axes[0][0].imshow(image)
axes[0][0].set_title("Original Image")
axes[0][1].imshow(Augmented_image1)
axes[0][1].set_title("Augmented Image1")
axes[1][0].imshow(Augmented_image2)
axes[1][0].set_title("Augmented Image2")
axes[1][1].imshow(Augmented_image3)
axes[1][1].set_title("Augmented Image3")
plt.show()

运行结果如下:

图3 原图及数据增强结果可视化(使用不同的size_percent参数)

可以从图3看到:

  • size_percent参数设置的越大时,增强后的新图像的每个黑椒噪声方块的尺寸会越小(size_percent和噪声方块尺寸的关系见size_percent的参数描述)。
    • size_percent=0.02时,每个黑椒噪声方块的尺寸都接近(50, 50),根据参数p确定将多少个区域替换为黑椒噪声方块。
    • size_percent=0.05时,每个黑椒噪声方块的尺寸都接近(20, 20),根据参数p确定将多少个区域替换为黑椒噪声方块。
    • size_percent=0.1时,每个黑椒噪声方块的尺寸都接近(10, 10),根据参数p确定将多少个区域替换为黑椒噪声方块。
  1. per_channel设置为True
import cv2
import imgaug.augmenters as iaa
import matplotlib.pyplot as plt

# 读取图像
img_path = r"D:\python_project\lena.png"
img = cv2.imread(img_path)
image = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)

# 创建数据增强器
aug1 = iaa.CoarsePepper(p=0.5, size_px=None, size_percent=0.02, per_channel=True, min_size=3, seed=0)
aug2 = iaa.CoarsePepper(p=0.5, size_px=None, size_percent=0.05, per_channel=True, min_size=3, seed=0)
aug3 = iaa.CoarsePepper(p=0.5, size_px=None, size_percent=0.1, per_channel=True, min_size=3, seed=0)

# 对图像进行数据增强
Augmented_image1 = aug1(image=image)
Augmented_image2 = aug2(image=image)
Augmented_image3 = aug3(image=image)

# 展示原始图像和数据增强后的图像
fig, axes = plt.subplots(2, 2, figsize=(10, 10))
axes[0][0].imshow(image)
axes[0][0].set_title("Original Image")
axes[0][1].imshow(Augmented_image1)
axes[0][1].set_title("Augmented Image1")
axes[1][0].imshow(Augmented_image2)
axes[1][0].set_title("Augmented Image2")
axes[1][1].imshow(Augmented_image3)
axes[1][1].set_title("Augmented Image3")
plt.show()

运行结果如下:

图4 原图及数据增强结果可视化(per_channel设置为True)

可以从图4看到:图像增强后的新图像将会出现彩色失真(不再是黑色的黑椒噪声)。
原因:当per_channel设置为True时,RGB的三个通道会独立进行处理,不一定能够同时替换为黑椒噪声块。

注意事项

  1. p的选择p参数决定了一副图像黑椒噪声的强度。较大的p值可能会导致新图像出现严重失真。需要根据具体场景选择合适的p
  2. size_px的选择size_px参数决定了黑椒噪声块的大小。错误地设置size_px值可能会导致原图完全被替换成黑椒噪声图像。需要根据具体场景选择合适的size_px
  3. size_percent的选择size_percent参数决定了黑椒噪声块的大小。错误地设置size_percent值也可能会导致原图完全被替换成黑椒噪声图像。需要根据具体场景选择合适的size_percent
  4. size_px和size_percent:若size_percentNone,则size_px参数必须设置;若size_pxNone,则size_percen参数必须设置;
  5. **随机性和可复现性(seed)**:如果需要可复现的结果,应该设置seed参数为一个固定的整数值。这将初始化随机数生成器,使得每次运行增强操作时都能得到相同的结果;
  6. 与其他增强操作的组合iaa.CoarsePepper可以与其他imgaug增强操作组合使用,以创建更复杂的增强管道。在组合多个增强操作时,应注意它们的顺序,因为不同的顺序可能会导致不同的最终效果。
  7. min_size的设置:合理地设置min_size可以预防因为错误地设置size_px参数或者size_percent参数导致原图被完全替换为黑椒噪声的问题。
  8. 谨慎设置per_channel参数:当per_channel设置为True时,RGB的三个通道会独立进行处理,导致出现彩色噪声块,并非常规的黑白黑椒噪声块。

总结

iaa.CoarsePepperimgaug库中的一个图像增强方法,用于向图像中添加粗糙的黑椒噪声。相比于iaa.Pepper,它的噪声颗粒更大,能够模拟更为粗糙的噪声模式。以下是该方法的总结:

  1. 作用:通过添加大范围的噪声块,模拟图像在恶劣条件下的噪声模式,或者用于创造特殊的艺术效果。

  2. 参数

    • p:定义了像素被替换为椒(黑色)的概率。
    • size_px:可用于定义噪声块的大小。
    • size_percent:可用于定义噪声块的大小。
    • per_channel:决定是否对每个通道独立地应用噪声。
    • min_size:定义噪声块的最小大小。
    • seed:用于设置随机数生成器的种子,以确保结果的可重复性。
    • name:增强器的名称。
  3. 用途

    • 增强大图像的视觉效果:在处理大图像时,通过添加大范围的噪声块来增强图像的细节和纹理。
    • 模拟恶劣天气条件下的图像:模拟由于恶劣天气(如雾、沙尘暴等)导致的较大范围的噪声干扰。
    • 创造艺术效果:通过控制噪声的大小和密度,在图像中创造特殊的艺术效果。

小结

imgaug是一个顶级的图像增强库,具备非常多的数据增强方法。它为你提供创造丰富多样的训练数据的机会,从而显著提升深度学习模型的性能。通过精心定制变换序列和参数,你能灵活应对各类应用场景,使我们在处理计算机视觉的数据增强问题时游刃有余。随着深度学习的持续发展,imgaug将在未来持续展现其不可或缺的价值。因此,明智之举是将imgaug纳入你的数据增强工具箱,为你的项目带来更多可能性。

参考链接


结尾

亲爱的读者,首先感谢抽出宝贵的时间来阅读我们的博客。我们真诚地欢迎您留下评论和意见,因为这对我们来说意义非凡。
俗话说,当局者迷,旁观者清。的客观视角对于我们发现博文的不足、提升内容质量起着不可替代的作用。
如果您觉得我们的博文给您带来了启发,那么,希望能为我们点个免费的赞/关注您的支持和鼓励是我们持续创作的动力
请放心,我们会持续努力创作,并不断优化博文质量,只为给带来更佳的阅读体验。
再次感谢的阅读,愿我们共同成长,共享智慧的果实!

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

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

相关文章

linux-nfc neard 编译与安装

项目github地址: https://github.com/linux-nfc/neard git clone地址: https://github.com/linux-nfc/neard.git clone完源码切换到目录neard里。这个项目需要依赖一下库: - GCC compiler - D-Bus library - GLib library - Netlink (lib…

go语言(一)----声明常量

package mainimport ("fmt""time" )func main() {fmt.Print("hello go!")time.Sleep(1 * time.Second)}运行后,结果如下: 1、golang表达式中,加;和不加;都可以 2、函数的{和函数名一…

.net core 6 使用注解自动注入实例,无需构造注入 autowrite4net

像java使用autowrite一样使用 1、前提先注册到ioc容器当中 builder.Services.AddScoped 2、nuget引入AutoWrite4Net 3、启用 //启用自动注入 app.UseAutoWrite(); 4、在类上使用注解 [StartAutoWrite] public class NacosController : ControllerBase 5、实例上使用注解 …

【Linux】nc 网络诊断 | 文件传输 命令详解

目录 一、命令简介 二、命令使用 2.1 测试服务器 2.2 端口连通性测试 2.2.1tcp端口连通性测试 2.2.2udp端口连通性测试 2.3 文件及目录的传输 2.3.1 文件传输(TCP端口) 2.3.2 文件传输(UDP端口) 相关文章: 【网络】抓包工具Wireshark下载安装和基本使用教…

强化加密生态合规性:Token Explorer 助你一臂之力!

随着加密市场监管的不断加强,项目的合规风险可能会在一夜之间威胁到其可行性。然而,通过智能的分析技术进行全面的代币审计,可以帮助我们及时发现问题,保护项目的声誉。 Token Explorer 提供智能的专业分析,让我们了解…

linux安装QQ(官方正版)

QQ官网上有支持linux系统的版本,所以去官网直接下载正版就好。 安装步骤: 1.进入官网:https://im.qq.com/linuxqq/index.shtml 2.选择版本:X86版下载dep 如下所示: 3.下载qq安装包: 4.使用命令安装qq s…

高考志愿填报系统开发技术语言选择总结

开发高考志愿填报系统,需要考虑到系统的稳定性、安全性、易用性以及数据准确性。以下是针对高考志愿填报系统的技术方案选择建议: 1.后端技术:可以使用Python、Java、PHP等后端语言进行开发,考虑到易用性和开发效率,可…

MetaGPT学习笔记 - task1task2

章节:task1&task2 一.github地址:github.com/geekan/MetaGPT 二.MetaGPT: 多智能体框架​ 使 GPT 以软件公司的形式工作,协作处理更复杂的任务 MetaGPT输入一句话的老板需求,输出用户故事 / 竞品分析 / 需求 / 数据结构 / A…

UI设计中插画赏析和产品色彩分析

插画赏析: 1. 插画是设计的原创性和艺术性的基础 无论是印刷品、品牌设计还是UI界面,更加风格化的插画能够将不同的风格和创意加入其中,在激烈的竞争中更容易因此脱颖而出。留下用户才有转化。 2. 插画是视觉触发器,瞬间传达大量…

React16源码: React中的异步调度scheduler模块的源码实现

React Scheduler 1 ) 概述 react当中的异步调度,称为 React Scheduler发布成单独的一个 npm 包就叫做 scheduler这个包它做了什么? A. 首先它维护时间片B. 然后模拟 requestIdleCallback 这个API 因为现在浏览器的支持不是特别的多所以在浏览当中只是去…

【报错】NVIDIA 驱动版本不兼容 — NVIDIA driver on your system is too old

【报错】NVIDIA 驱动版本不兼容 — NVIDIA driver on your system is too old 报错信息查看torch版本查看nvidia驱动版本 报错信息 CUDA initialization: The NVIDIA driver on your system is too old (found version 11040). Please update your GPU driver by downloading …

投资半导体行业可靠吗?九方智投洪帮主助投资者深度剖析市场

近期,CES2024展会火热袭来,作为行业内知名活动,展会的官方数据显示本次参展企业达到了4000家。作为CES2024的特色主题,人工智能有望成为会议的重大亮点。 人工智能涉及到的领域包含方方面面,其中AI软件和硬件解决方案的发布将促进半导体行业需求,算力芯片和边缘侧AI的机会值得关…

纯前端实现加减运算验证码

纯前端实现加减运算验证码 实现效果 //页面展示 <template><view class"form-input-item" style"padding:8rpx 22rpx;"><input class"form-input" placeholder"请输入验证码" type"text" maxlength"6…

【计算机硬件】3、输入输出技术、总线结构

文章目录 输入输出技术内存与接口地址的编址方法1、 内存与接口地址独立编址方法2、内存与接口地址统一编址方法 计算机和外设间的数据交互方式1、程序控制(查询)方式2、程序中断方式3、DMA方式&#xff08;直接主存存取&#xff09; 总线结构 输入输出技术 内存与接口地址的编…

智能组网和云桥通sd-wan企业组网技术方案的区别对比

智能组网和云桥通sd-wan企业组网是两种不同的网络技术方案&#xff0c;它们在设计理念、应用场景和功能特点上存在以下这些区别&#xff1a; 1. 定义与设计理念&#xff1a; 智能组网&#xff1a; 智能组网是一种综合利用人工智能、自动化和网络管理技术的网络组建和管理方案。…

链表练习 Leetcode82.删除排序链表中的重复元素 II

题目传送门&#xff1a;Leetcode82 给定一个已排序的链表的头 head &#xff0c; 删除原始链表中所有重复数字的节点&#xff0c;只留下不同的数字 。返回 已排序的链表 。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,3,4,4,5] 输出&#xff1a;[1,2,5]示例 2&#xff1…

抖音直播间爆品如何打造培训教程课件

【干货资料持续更新&#xff0c;以防走丢】 抖音直播间爆品如何打造培训教程课件 部分资料预览 资料部分是网络整理&#xff0c;仅供学习参考。 抖音运营资料合集&#xff08;完整资料包含以下内容&#xff09; 目录 通过数据确定爆品的短视频自然流选方法 在抖音这样的短…

SC20-EVB ubuntu14.04 Andriod 5.1 SDK编译下载

1.ubuntu14.04安装环境配置 vi /etc/profile to add export JAVA_HOME/usr/lib/jvm/java-7-openjdk-amd64 export JRE_HOME J A V A H O M E / j r e e x p o r t C L A S S P A T H . : {JAVA_HOME}/jre export CLASSPATH.: JAVAH​OME/jreexportCLASSPATH.:{JAVA_HOME}/lib…

亚信安慧AntDB-S流式数据库实现企业数智化转型

AntDB-S流式数据库是一项针对实时数仓等场景的创新技术&#xff0c;旨在取代传统的流式处理引擎&#xff0c;从而简化开发和测试过程。该流式数据库具备强大的ACID特性和高可用性&#xff0c;为企业降低了流式业务开发和维护的成本。AntDB-S不仅将数据存储、计算和管理集成为一…

SQL语句详解四-DQL(数据查询语言-多表查询一)

文章目录 表和表的关系一对一关系一对多、多对一关系多对多关系 表和表的关系 概述&#xff1a;数据库中表的关系有三种&#xff0c;一对一关系、一对多的关系、多对多的关系。 一对一关系 例如&#xff1a;一个人只能有一个身份证号&#xff0c;一个身份证号只属于一个人 示…