R 是一种动态类型语言,使用灵活,变量无需预先声明类型。掌握 R 的数据类型和变量机制,是后续进行数据处理和建模分析的基础。本章节主要介绍 R 语言中的常量、变量、基本数据类型及常用数据结构,并结合示例进行说明。

文章目录

    • 一、常量(Constants)
      • 1. 数值型常量
      • 2. 字符型常量
      • 3. 逻辑型常量
      • 4. 缺失值常量
      • 5. 复数常量
    • 二、变量(Variables)
      • 1. 变量名命名规则
      • 2. 变量赋值方式
      • 3. 动态类型语言特征
    • 三、基本数据类型(Atomic Types)
    • 四、常用数据结构(Data Structures)
      • 1. 向量(vector)
      • 2. 矩阵(matrix)
      • 3. 数据框(data.frame)
      • 4. 列表(list)
      • 5. 因子(factor)
    • 五、数据访问与子集提取
      • 1. 向量访问
      • 2. 数据框访问
      • 3. 列表访问
    • 六、数值型向量及其运算(Numeric Vectors and Their Operations)
      • 1. 数值型向量的创建
      • 2. 标量与标量运算
      • 3. 向量与标量运算
      • 4. 向量与向量运算
      • 5. 向量函数与向量化计算
      • 6. 排序函数与顺序函数
      • 7. 常用统计函数
      • 8. 序列与重复生成函数
      • 9. 复数向量
    • 七、逻辑型向量及其运算(Logical Vectors and Logical Operations)
      • 1. 逻辑型向量与比较运算
        • 比较运算符包括:
      • 2. 逻辑运算
      • 3. 逻辑运算函数
      • 4.其他常用逻辑函数:
    • 八、字符型数据及其处理(Character Data and String Handling)
      • 1. 字符型向量
      • 2. 转义字符与原始字符串
      • 3. 字符串拼接:`paste()` 函数
      • 4. 转换大小写
      • 5. 字符串长度计算
      • 6. 提取子串
      • 7. 类型转换
      • 8. 字符串替换
      • 9. 正则表达式匹配
    • 参考引用

一、常量(Constants)

常量是指程序中直接写出的固定值,例如数字、字符串、逻辑值、复数等。在 R 中,常量具有不同的表现形式。

1. 数值型常量

数值型常量包括整数、浮点数和科学计数法表示形式。例如:

x1 <- 123
x2 <- -0.012
x3 <- 1.23e2   # 等价于123
x4 <- 123L     # 表示整数类型(L 结尾)

2. 字符型常量

字符常量是由双引号或单引号括起来的文本。在 R 中,字符类型用于表示字符串:

name1 <- "Li Ming"
name2 <- '李明'

注意:R 没有单独的“字符(character)”类型和“字符串(string)”类型,二者统一称为 character。

3. 逻辑型常量

逻辑型常量仅包括 TRUEFALSE,表示布尔值:

flag1 <- TRUE
flag2 <- FALSE
flag3 <- flag1 & flag2   # 与操作

4. 缺失值常量

R 使用 NA 表示缺失值,广泛出现在统计分析中。

v <- c(1, 2, NA, 4)
mean(v)                  # 返回 NA
mean(v, na.rm = TRUE)    # 去除缺失值后计算均值

字符型空白不会自动识别为 NA,需要手动转换。

5. 复数常量

R 支持复数类型。复数常量的形式如下:

z <- 2 + 3i
Mod(z)    # 计算复数的模长

二、变量(Variables)

程序语言中的变量用来保存输入的值或者计算得到的值。在 R 中,变量可以保存所有类型的数据,包括标量、向量、矩阵、数据框、函数等。

1. 变量名命名规则

变量名是变量的标识符。R 语言的变量命名需要遵循以下规则:

  • 由字母、数字、下划线 _ 和句点 . 组成;
  • 第一个字符不能为数字;
  • R 中变量名区分大小写,如 xX 是两个不同的变量;
  • 在中文操作系统中,也可以使用中文作为变量名(不推荐)。
x <- 10
y <- 20
Data_1 <- "变量"
变量名 <- "合法但不推荐"

2. 变量赋值方式

R 中常用 <- 进行赋值,也可使用 =。建议优先使用 <-,更符合 R 编程规范。

a <- 5
b = 10
sum <- a + b
print(sum)

3. 动态类型语言特征

R 是动态类型语言,变量的类型在赋值时自动确定,可以随时被修改为其他类型:

x <- 1.5        # 数值型
x <- "abc"      # 重新赋值为字符型
x <- TRUE       # 再次赋值为逻辑型

尽管 R 支持类型切换,实际编程中应避免频繁更改同一变量的类型。


三、基本数据类型(Atomic Types)

R 语言的基本数据类型包括以下几类:

类型示例类型判断函数
数值型x <- 3.14is.numeric(x)
整数型x <- 5Lis.integer(x)
字符型x <- "text"is.character(x)
逻辑型x <- TRUEis.logical(x)
复数型x <- 1+2iis.complex(x)

可使用 typeof()class() 查看变量类型:

x <- 3.14
typeof(x)   # 返回 "double"
class(x)    # 返回 "numeric"

四、常用数据结构(Data Structures)

R 支持多种数据结构,用于组织和管理不同类型和维度的数据。

1. 向量(vector)

向量是 R 最基本的数据结构,包含相同类型的一组元素。

v <- c(1, 2, 3, 4)
length(v)       # 返回元素个数
mean(v)         # 求均值

2. 矩阵(matrix)

矩阵是二维向量,所有元素类型必须一致。

m <- matrix(1:6, nrow = 2, byrow = TRUE)
print(m)

3. 数据框(data.frame)

数据框是类似于表格的二维数据结构,每列可以是不同类型

df <- data.frame(name = c("Tom", "Amy"),score = c(90, 85),passed = c(TRUE, FALSE)
)
print(df)

4. 列表(list)

列表是一种可容纳任意类型对象的数据结构,常用于模型输出、函数返回值等场景。

lst <- list(id = 1,name = "Tom",scores = c(85, 90)
)
lst$name

5. 因子(factor)

因子用于存储分类变量,有固定的水平(levels)。

gender <- factor(c("Male", "Female", "Male"))
levels(gender)
summary(gender)

五、数据访问与子集提取

R 提供多种方式访问数据结构中的元素。

1. 向量访问

v <- c(100, 200, 300)
v[2]         # 返回第二个元素

2. 数据框访问

df <- data.frame(id = 1:3, score = c(80, 85, 90))df[1, 2]          # 第1行第2列
df$score          # 按列名访问
df[df$score > 80, ]  # 筛选得分大于80的行

3. 列表访问

lst <- list(name = "Amy", age = 25)
lst$name
lst[["age"]]

六、数值型向量及其运算(Numeric Vectors and Their Operations)

1. 数值型向量的创建

R 语言中,数值型向量是由一组数值组成的线性结构,是最基本的数据单位。可以使用 c() 函数将多个数值组合成一个向量,也可以通过冒号 :seq() 函数生成等差数列。

x <- c(10, 6, 4, 7, 8)
y <- c(1:3, 10:13)
z1 <- c(1, 2)
z2 <- c(3, 4)
z <- c(z1, z2)
numeric(5)    # 创建一个元素全部为 0、长度为 5 的向量
length(z)     # 返回向量的长度

长度为 0 的向量用 numeric(0) 表示。


2. 标量与标量运算

R 中的标量(单个数值)本质上是长度为 1 的向量,支持加减乘除乘方等常见运算:

1.5 + 2.3 - 0.6 + 2.1 * 1.2 - 1.5 / 0.5 + 2^3
## [1] 10.72# 使用括号控制优先级
1.5 + 2.3 - (0.6 + 2.1) * 1.2 - 1.5 / 0.5 + 2^3
## [1] 5.56

R 还支持整除(%/%)和取余(%%):

5 %/% 3    # 商为 1
5 %% 3     # 余数为 2

3. 向量与标量运算

向量与标量进行运算时,会将标量扩展为与向量等长,逐元素进行运算:

x <- c(1, 10)x + 2      # 每个元素加 2
x * 2      # 每个元素乘 2
2 ^ x      # 以 2 为底,对 x 中每个元素进行乘方

缺失值参与运算会返回缺失:

c(1, NA, 3) + 10
## [1] 11 NA 13

4. 向量与向量运算

两个等长向量进行运算时,按对应元素逐一计算:

x1 <- c(1, 10)
x2 <- c(4, 2)x1 + x2    # [1]  5 12
x1 * x2    # [1]  4 20

如果向量长度不一致,但较长者是较短者长度的整数倍,R 会自动重复短向量的元素:

x1 <- c(10, 20)
x2 <- c(1, 3, 5, 7)x1 + x2
## [1] 11 23 15 27

若长度不是整数倍,将返回计算结果但伴随警告信息:

c(1, 2) + c(1, 2, 3)
## Warning: longer object length is not a multiple of shorter object length

5. 向量函数与向量化计算

R 中的许多数学函数都是向量化的,接受向量输入并返回对应的向量输出:

sqrt(c(1, 4, 6.25))
## [1] 1.0 2.0 2.5log10(c(1, 10, 100))
exp(c(0, 1, 2))

常用函数包括:

  • 平方根:sqrt()
  • 对数与指数:log(), log10(), exp()
  • 绝对值与符号:abs(), sign()
  • 三角函数:sin(), cos(), tan()
  • 舍入:round(), floor(), ceiling(), trunc()

6. 排序函数与顺序函数

排序函数可以用于向量排序及下标操作:

x <- c(33, 55, 11)sort(x)         # 升序排列
rev(sort(x))    # 降序排列
order(x)        # 获取排序下标
x[order(x)]     # 排序后的向量

7. 常用统计函数

R 中统计函数直接作用于数值向量,计算基本统计量:

x <- c(88, 92, 76, 81, 95, 67, 90, 85, 73, 89)mean(x)     # 平均值
sd(x)       # 标准差
min(x)      # 最小值
max(x)      # 最大值
median(x)   # 中位数
sum(x)      # 总和
range(x)    # 范围

还有累计函数:

cumsum(1:5)     # 累计和
cumprod(1:5)    # 累计积

8. 序列与重复生成函数

使用 seq() 生成规则数列,rep() 生成重复模式:

seq(1, 10, by = 2)
## [1] 1 3 5 7 9rep(0, 5)                        # 生成五个零
rep(c(1, 3), 2)                  # [1] 1 3 1 3
rep(c(1, 3), each = 2)           # [1] 1 1 3 3
rep(c(1, 3), times = c(2, 4))    # [1] 1 1 3 3 3 3

seq(): 区别:1:5 生成整数序列,seq(1, 5, by=1) 更灵活,可设步长、长度。


9. 复数向量

R 中可用 complex() 生成复数向量,支持实部、虚部或模角定义:

z <- complex(real = c(1, 0, -1, 0), imaginary = c(0, 1, 0, -1))
z
## [1]  1+0i  0+1i -1+0i  0-1iRe(z); Im(z); Mod(z); Arg(z); Conj(z)

当运算涉及复数时,需显式写出复数形式:

sqrt(-1)
## NaN with warningsqrt(-1 + 0i)
## [1] 0+1i

七、逻辑型向量及其运算(Logical Vectors and Logical Operations)

1. 逻辑型向量与比较运算

逻辑型(logical)是 R 的基本数据类型之一,只有两个取值:TRUEFALSE,缺失值表示为 NA。逻辑值通常来源于比较表达式。例如:

sele <- (log10(15) < 2)
print(sele)
## [1] TRUE

对向量进行比较时,会生成逻辑型向量,结果逐元素返回布尔值:

c(1, 3, 5) > 2
## [1] FALSE  TRUE  TRUE(1:4) >= (4:1)
## [1] FALSE FALSE  TRUE  TRUE

R 的比较遵循向量间运算的一般规则:

  • 向量与标量之间比较:每个元素与标量分别比较;
  • 等长向量比较:对应元素逐一比较;
  • 不等长但满足倍数关系:较短向量从头重复利用。

含缺失值的比较将产生 NA

c(1, NA, 3) > 2
## [1] FALSE    NA  TRUENA == NA
## [1] NA

is.na() 判断是否为缺失值,用 is.finite() 判断是否为有限值:

is.na(c(1, NA, 3) > 2)
## [1] FALSE  TRUE FALSE
比较运算符包括:
运算符含义
<小于
<=小于等于
>大于
>=大于等于
==等于(注意两个等号)
!=不等于
%in%是否属于集合

%in% 将右侧向量视为集合,判断左侧元素是否存在其中:

c(1, 3) %in% c(2, 3, 4)
## [1] FALSE  TRUEc(NA, 3) %in% c(NA, 3, 4)
## [1] TRUE TRUE

函数 match(x, y)%in% 类似,但返回的是匹配元素在 y 中首次出现的位置,若找不到返回 NA

match(c(1, 3), c(2, 3, 4, 3))
## [1] NA  2

2. 逻辑运算

为了表达复合条件,可以使用逻辑运算符将多个逻辑表达式连接:

运算符含义
&与(元素级)
``
!非(取反)
xor()异或:只在不相等时为真

示例:

age <- c(2, 5, 3, 6)
sex <- c("女", "女", "男", "男")# 女婴(年龄≤3且性别为女)
age <= 3 & sex == "女"
## [1]  TRUE FALSE FALSE FALSE# 婴儿或女性
age <= 3 | sex == "女"
## [1]  TRUE  TRUE  TRUE FALSE# 既非婴儿也非女性
!(age <= 3 | sex == "女")
## [1] FALSE FALSE FALSE  TRUE

短路逻辑运算符 &&|| 只比较第一个元素,常用于 ifwhile 等流程控制语句中:

if (TRUE || sqrt(-1) > 0) print("不会报错")

由于 TRUE || ... 的结果已确定,右侧不会被执行,避免了运行错误。


3. 逻辑运算函数

有时需要从逻辑型向量中计算汇总结果,R 提供了如下函数:

  • all(x):所有元素为 TRUE 时返回 TRUE
  • any(x):任意一个元素为 TRUE 即返回 TRUE
  • which(x):返回逻辑值为 TRUE 的下标

示例:

cond <- c(1, NA, 3) > 2all(cond)
## [1] FALSEany(cond)
## [1] TRUEwhich(cond)
## [1] 3

当逻辑向量全为缺失时:

all(NA)
## [1] NAany(NA)
## [1] NA

4.其他常用逻辑函数:

  • identical(x, y):判断两个对象是否完全相同(类型和值均一致)
  • all.equal(x, y):判断两个对象是否“接近相等”,常用于数值误差容忍比较
  • duplicated(x):判断每个元素是否在前面出现过
  • unique(x):返回去重后的结果

示例:

duplicated(c(1, 2, 1, 3, NA, 4, NA))
## [1] FALSE FALSE  TRUE FALSE FALSE FALSE  TRUEunique(c(1, 2, 1, 3, NA, 4, NA))
## [1]  1  2  3 NA  4
identical(c(1L, 2L, 3L), c(1, 2, 3))
## [1] FALSE    # 类型不一致:一个是整数,一个是双精度all.equal(c(1L, 2L, 3L), c(1, 2, 3))
## [1] TRUE

八、字符型数据及其处理(Character Data and String Handling)

1. 字符型向量

字符型向量是元素为字符串的一类向量。在 R 中,字符串使用双引号 "" 或单引号 '' 包裹。例如:

s1 <- c('abc', '', 'a cat', NA, '李明')

注意:空字符串 "" 不能自动识别为缺失值,字符型的缺失值需显式写为 NA

字符串的常见来源包括文件读取、网络请求、数据库提取等,也可以直接在代码中写出。


2. 转义字符与原始字符串

在字符串中包含特殊字符(如引号、换行符)时需使用反斜杠 \ 进行转义:

cat("\"\n")
## "

\n 表示换行。若字符串中包含较多转义内容,可使用原始字符串语法 r"(...)"

cat(r"(C:\disk\course\math\nFinished!\n)")
## C:\disk\course\math\nFinished!\n

若原始字符串中包含圆括号 (),可改用 []{},必要时还可加减号标识范围:

r"[(...)]"、r"{...}"、r"--((...))--"

3. 字符串拼接:paste() 函数

paste() 是处理字符型向量最常用的函数。默认逐元素拼接,并以空格分隔:

paste(c("ab", "cd"), c("ef", "gh"))
## [1] "ab ef" "cd gh"

R 遵循向量化运算规则,支持数值自动转换为字符串:

paste("x", 1:3)
## [1] "x 1" "x 2" "x 3"
  • 使用 sep= 可指定分隔符:

    paste("x", 1:3, sep = "")
    ## [1] "x1" "x2" "x3"
    
  • 使用 collapse= 可将整个字符向量合并为单个字符串:

    paste(c("a", "b", "c"), collapse = "")
    ## [1] "abc"
    

4. 转换大小写

R 提供了大小写转换函数:

  • toupper() 将字符串转换为大写;
  • tolower() 将字符串转换为小写。
toupper("aB cd")
## [1] "AB CD"tolower(c("aB", "CD"))
## [1] "ab" "cd"

该方法常用于不区分大小写的比较:

toupper("jan") == "JAN"
## [1] TRUE

5. 字符串长度计算

  • nchar(x, type = "chars"):按字符数统计(中文一个字符);
  • nchar(x, type = "bytes"):按字节统计(中文通常占两个字节)。
x <- c("abc", "李明")
nchar(x, type = "chars")   # [1] 3 2
nchar(x, type = "bytes")   # [1] 3 6

绘图时可用 strwidth() 计算文本所占空间宽度。


6. 提取子串

  • substr(x, start, stop):提取指定起止位置的子串;
  • substring(x, start):从指定位置提取到末尾。
substr("JAN07", 1, 3)
## [1] "JAN"substr(c("JAN07", "MAR66"), 1, 3)
## [1] "JAN" "MAR"substring(c("JAN07", "MAR66"), 4)
## [1] "07" "66"

7. 类型转换

  • as.numeric() 将字符串转换为数值;
  • as.character() 将数值转换为字符串;
  • sprintf() 进行格式控制的转换;
  • 使用 readr::parse_number() 提取字符串中的数值部分。
as.numeric(substr("JAN07", 4, 5)) + 2000
## [1] 2007as.character((1:5)*5)
## [1] "5"  "10" "15" "20" "25"sprintf("file%03d.txt", c(1, 99, 100))
## [1] "file001.txt" "file099.txt" "file100.txt"readr::parse_number(c("output-123.txt", "30.2%", "abc"))
## [1] -123.000  30.200       NA

parse_number() 可提取字符串中的数值部分,而 parse_integer() 等函数则要求字符串完全为目标类型,否则返回 NA 并提供提示信息。


8. 字符串替换

gsub() 函数可以实现字符串中模式的替换操作,例如将标点统一或清理空格:

x <- "1, 3; 5"
gsub(";", ",", x, fixed = TRUE)
## [1] "1, 3, 5"

此类功能常用于数据预处理、文本清洗等场景。


9. 正则表达式匹配

正则表达式(regular expression)可用于模式匹配、查找与替换等高级文本处理。R 中支持 Perl 风格的正则语法,常用函数包括:

  • grepl() / grep():匹配查询;
  • gsub() / sub():替换操作。

示例:替换多个空格为一个空格

gsub("[[:space:]]+", " ", "a   cat  in a box", perl = TRUE)
## [1] "a cat in a box"

正则表达式具有强大表达能力,在处理网络抓取文本、自然语言处理等任务中应用广泛。


参考引用

  1. Wickham, H., & Grolemund, G. (2016). R for Data Science. O’Reilly Media.
    在线阅读:https://r4ds.hadley.nz

  2. R 官方语言手册
    https://cran.r-project.org/manuals.html

  3. RDocumentation: R 函数与包参考平台
    https://www.rdocumentation.org

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

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

UI前端大数据处理优化策略:提升数据处理速度与准确性

hello宝子们...我们是艾斯视觉擅长ui设计、前端开发、数字孪生、大数据、三维建模、三维动画10年经验!希望我的分享能帮助到您!如需帮助可以评论关注私信我们一起探讨!致敬感谢感恩! 在数字化浪潮下&#xff0c;前端面临的数据规模正呈指数级增长 ——IDC 预测&#xff0c;2025…

技术调研:时序数据库(二)

除了 InfluxDB、TDengine 和 TimescaleDB&#xff0c;还有其他多个主流的开源时序数据库&#xff0c;各自针对不同场景优化。以下是补充的时序数据库选型清单&#xff0c;涵盖其核心特性、适用场景及局限性&#xff1a; 1. 监控与运维场景 (1) Prometheus 核心优势&#xff1…

【C++/C】十进制数转为十六进制时,如何区分正负? 负数补码高位是1,那么一个很大的正数,高位也会出现1,会和负数搞混吗?

文章目录 1 十进制数转为十六进制时&#xff0c;如何区分正负&#xff1f;1.1 正数处理1.2 负数处理‌1.3 关键点‌ 2 负数补码高位是1&#xff0c;那么一个很大的正数&#xff0c;高位也会出现1&#xff0c;会和负数搞混吗&#xff1f;2.1 符号位明确区分‌2.2 补码的数值范围…

Elasticsearch 如果保证读写一致

Elasticsearch 通过多机制组合保障读写一致性&#xff0c;针对高并发场景优化设计&#xff0c;具体实现如下&#xff1a; 一、写入一致性控制‌ ‌1.1 一致性级别参数&#xff08;consistency&#xff09;‌ 写操作时指定分片确认数量&#xff0c;确保数据可靠同步&am…

内嵌lua解释器 作为组件命令调试

给不同的组件传递不通的参数 好处就是调试代码 只在 lua 代码出现&#xff0c;同时为设备初始化 增加了外部脚本配置的功能接口

Excel工具箱WPS版 增强插件 文本处理、批量录入 数据对比 高级排序

各位Excel办公达人们&#xff0c;今天咱来聊聊方方格子Excel工具箱V3.6.6.0&#xff08;WPS版&#xff09;&#xff01;这玩意儿啊&#xff0c;就是专门给WPS Office用户量身打造的Excel增强插件。它集成了上百项实用功能&#xff0c;能帮咱高效处理数据、优化表格操作&#xf…

创建AWS Bedrock知识库及填坑指南

前言 作者之前的关于Dify实践RAG系统的文章&#xff1a;用它搭建AI Agent原来这么简单&#xff01;-CSDN博客&#xff0c;文末留了TODO&#xff1a; “后面会对此RAG系统进行扩展和增强&#xff1a; 1&#xff09;知识库同步自Web站点 2&#xff09;链接外部知识库 3&…

Swift 变量

Swift 变量 在 Swift 编程语言中,变量是存储数据的基本方式。它们用于在程序的运行过程中保存和修改数据。理解 Swift 中的变量类型和用法对于编写高效、可维护的代码至关重要。 变量的定义 变量在 Swift 中是通过关键字 var 来定义的。定义变量时,需要指定变量存储的数据…

板凳-------Mysql cookbook学习 (十--9)

8.15 基于日期的摘要 Monday, June 23, 2025 mysql> use cookbook Database changed mysql> select trav_date,-> count(*) as number of drivers, sum(miles) as miles logged-> from driver_log group by trav_date; -----------------------------------------…

redis的scan使用详解,结合spring使用详解

Redis的SCAN命令是一种非阻塞的迭代器&#xff0c;用于逐步遍历数据库中的键&#xff0c;特别适合处理大数据库。下面详细介绍其使用方法及在Spring框架中的集成方式。 SCAN命令基础 SCAN命令的基本语法&#xff1a; SCAN cursor [MATCH pattern] [COUNT count]cursor&#…

Go 语言并发模式实践

在 Go 语言并发编程中&#xff0c;合理的并发模式能显著提升程序的可维护性和性能。本文将深入解析三种典型的并发模式实现&#xff0c;通过具体案例展示如何优雅地管理任务生命周期、资源池和工作 goroutine 池。 一、runner 模式&#xff1a;任务生命周期管理 在定时任务、…

【Java 开发日记】你会不会使用 SpringBoot 整合 Flowable 快速实现工作流呢?

目录 1、流程引擎介绍 2、创建项目 3、画流程图 4、开发接口 4.1 Java 类梳理 ProcessDefinition ProcessInstance Activity Execution Task 4.2 查看流程图 4.3 开启一个流程 4.4 将请求提交给组长 4.5 组长审批 4.6 经理审批 4.7 拒绝流程 1、流程引擎介绍 …

面试150 分发糖果

思路 联想贪心算法&#xff0c;遍历两次数组&#xff0c;一次是从左到右遍历&#xff0c;只比较右边孩子评分比左边打的情况。第二次从右到左遍历&#xff0c;只比较左边孩子评分比右边大的情况。最后求和即可 class Solution:def candy(self, ratings: List[int]) -> int…

csp基础之进制转换器

一、进制转换要明白的基础知识。。。 1、什么是进制&#xff1f; 进制也就是进位计数制&#xff0c;是人为定义的带进位的计数方法。对于任何一种进制 X 进制&#xff0c;就表示每一位置上的数运算时都是逢 X 进一位。十进制是逢十进一&#xff0c;十六进制是逢十六进一&#…

Zephyr OS蓝牙广播(Advertising)功能实现

目录 概述 1 Advertising功能介绍 1.1 实现原理 1.2 广播类型 1.3 广播数据格式 1.4 优化建议 1.5 常见问题和解决方法 2 Nordic 蓝牙广播&#xff08;Advertising&#xff09;功能实现 2.1 环境准备与SDK基础 2.2 广播功能实现 2.3 广播优化与最佳实践 3 实际应用案例…

服务器不支持PUT,DELETE 的解决方案

nginx 的更改&#xff1a; set $method $request_method; if ($http_X_HTTP_Method_Override ~* PUT|DELETE) { set $method $http_X_HTTP_Method_Override; } proxy_method $method; axios 的更改&#xff1a; const method config.me…

从0开始学习计算机视觉--Day04--线性分类

从宏观来看&#xff0c;卷积网络可以看做是由一个个不同的神经网络组件组合而成&#xff0c;就像积木一样通过不同类型的组件搭建形成&#xff0c;其中线性分类器是一个很重要的组件&#xff0c;在很多卷积网络中都有用到&#xff0c;所以了解清楚它的工作原理对我们后续的学习…

基于ComfyUI与Wan2.1模型的本地化视频生成环境搭建指南

文章目录 前言1.软件准备1.1 ComfyUI1.2 文本编码器1.3 VAE1.4 视频生成模型2.整合配置3. 本地运行测试4. 公网使用Wan2.1模型生成视频4.1 创建远程连接公网地址5. 固定远程访问公网地址总结前言 各位小伙伴们,今天我们将为您展示一套创新的人工智能应用方案!本次教程将指导…

Vue 2 项目中内嵌 md 文件

推荐方案&#xff1a;raw-loader marked 解析 Markdown 第一步&#xff1a;安装依赖 npm install marked --save npm install raw-loader --save-dev第二步&#xff1a;配置 webpack 支持 .md 文件 打开 vue.config.js 或 webpack.config.js&#xff0c;添加以下配置&#…

Spring AI初识及简单使用,快速上手。

Spring AI简介 在当今这样一个快速发展的技术时代&#xff0c;人工智能&#xff08;AI&#xff09;已经成为各行各业的一种标配。而作为一款主流的Java应用开发框架Spring&#xff0c;肯定会紧跟时代的潮流&#xff0c;所以&#xff0c;推出了Spring AI框架。 官网描述&#…