91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

R語言向量下標和子集怎么用

發布時間:2022-03-04 13:36:30 來源:億速云 閱讀:236 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關R語言向量下標和子集怎么用,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

1.正整數下標

首先定義一個x,然后對向量 x, 在后面加方括號和下標可以訪問向量的元素和子集,如:

 定義一個x:

x <- c(1, 4, 6.25)
x

返回:

R語言向量下標和子集怎么用

我們取出第二個元素:

x[2]

返回:

R語言向量下標和子集怎么用

我們再修改第二個元素為 99 :

x[2] <- 99; x

返回:

R語言向量下標和子集怎么用

我們再取下第 1、3 號元素 :

x[c(1,3)]

返回:

R語言向量下標和子集怎么用

我們再修改第 1、3 號元素為 11,13 :

x[c(1,3)] <- c(11, 13); x

返回:

R語言向量下標和子集怎么用

         若是下標可重復,又會如何,如:

x[c(1,3,1)]

返回:

R語言向量下標和子集怎么用

2.負整數下標

負下標表示扣除相應的元素后的子集,如

x <- c(1,4,6.25)
x[-2]

-2 表示倒數第二個;返回:

R語言向量下標和子集怎么用

再比如:

x[-c(1,3)]

返回:

R語言向量下標和子集怎么用

負整數下標不能與正整數下標同時用來從某一向量中取子集,比如

x[c(1,-2)]

返回結果會報錯:

R語言向量下標和子集怎么用

3.空下標與零下標

x[] 表示取 x 的全部元素作為子集。這與 x 本身不同,比如

x <- c(1,4,6.25)
x[]

返回:

R語言向量下標和子集怎么用

然后,我們對x 內的值進行修改

x[] <- 999
x

返回:

R語言向量下標和子集怎么用

再如,另一種對x內的值進行修改

x <- c(1,4,6.25)
x <- 999
x

返回結果只有一個值:

R語言向量下標和子集怎么用

 可能有人會問是否有 x[0] ,那就讓我們看看

x[0]

返回:

R語言向量下標和子集怎么用

那說明,x[0] 是一種少見的做法,結果返回類型相同、長度為零的向量,如 numeric(0)

相當于空集;且當 0 與正整數下標一起使用時會被 忽略。當 0 與負整數下標一起使用時也會被 忽略。

4.下標超界

設向量 x 長度為 n , 則使用正整數下標時下標應在 { 1 , 2 , . . . , n } 中取值。

x <- c(1,4,6.25)
x[2]

返回:

R語言向量下標和子集怎么用

如果使用大于 n 的下標,讀取時返回缺失值,并不出錯。

x[5]

返回:

R語言向量下標和子集怎么用

超出 n 的下標元素賦值,則向量自動變長,中間沒有賦值的元素為缺失值。例如

x[5] <- 9 
x

返回:

R語言向量下標和子集怎么用

雖然 R 的語法對下標超界不視作錯誤,但是這樣的做法往往來自不良的程序思路,而且對程序效率有影響,所以實際編程中應避免下標超界

5.邏輯下標

下標可以是與向量等長的邏輯表達式,一般是關于本向量或者與本向量等長的其它向量的比較結果,如 定義x

x <- c(1,4,6.25)

取出 x 的大于 3 的元素組成的子集

x[x > 3]

返回:

R語言向量下標和子集怎么用

邏輯下標除了用來對向量取子集,還經常用來對數據框取取子集,也用在向量化的運算中。例如,對如下示性函數

R語言向量下標和子集怎么用

輸入向量 x ,結果 y 需要也是一個向量,程序可以寫成

f <- function(x){
y <- numeric(length(x))
y[x >= 0] <- 1
y[x < 0] <- 0 # 此語句多余
y }

事實上還有一種寫法,向量化的邏輯選擇有一個 ifelse() 函數,比如,對上面的示性函數,如果 x 是一個向量,輸出 y 向量可以寫成 

y <- ifelse(x>=0, 1, 0)

要注意的是,如果邏輯下標中有缺失值,對應結果也是缺失值,如

x <- c(1, 4, 6.25, NA)
x[x > 2]

返回:

R語言向量下標和子集怎么用

所以,在用邏輯下標作子集選擇時,一定要考慮到缺失值問題。 正確的做法是加上!is.na 前提,如

x[!is.na(x) & x > 2]

返回:

R語言向量下標和子集怎么用

6. which()、which.min()、which.max() 函數

函數 which() 可以用來找到滿足條件的下標,如

x <- c(3, 4, 3, 5, 7, 5, 9)
which(x > 5)

返回:

R語言向量下標和子集怎么用

seq(along=x) 會生成由 x 的下標組成的向量,如

seq(along=x)[x > 5]

返回:

R語言向量下標和子集怎么用

which.min()which.max() 求最小值的下標和最大值的下標,不唯一時只取第一個。如

which.min(x)
which.max(x)

返回:

R語言向量下標和子集怎么用

7. 元素名

向量可以為每個元素命名。如

ages <- c(" 李明"=30, " 張聰"=25, " 劉穎"=28)

ages <- c(30, 25, 28)
names(ages) <- c(" 李明", " 張聰", " 劉穎")

ages <- setNames(c(30, 25, 28), c(" 李明", " 張聰", " 劉穎"))

這時可以用元素名或元素名向量作為向量的下標,如

ages[" 張聰"]

返回:

R語言向量下標和子集怎么用

 再如:

ages[c(" 李明", " 劉穎")]

返回:

R語言向量下標和子集怎么用

再如,修改字符串數值:

ages[" 張聰"] <- 26

用字符串作為下標時,如果該字符串不在向量的元素名中,讀取時返回缺失值結果,賦值時該向量會增加一個元素并以該字符串為元素名。 帶有元素名的向量也可以是字符型或其它基本類型,如

sex <- c(" 李明"=" 男", " 張聰"=" 男", " 劉穎"=" 女")

除了給向量元素命名外,在矩陣和數據框中還可以給行、列命名,這會使得程序的擴展更為容易和安全。 R 允許僅給部分元素命名,這時其它元素名字為空字符串。不同元素的元素名一般應該是不同的,否則在使用元素作為下標時會發生誤讀,但是 R 語法允許存在重名。 用 unname(x) 返回去掉了元素名的 x 的副本,用 names(x) <- NULL 可以去掉 x 的元素名。

8.用 R 向量下標作映射

R 在使用整數作為向量下標時,允許使用重復下標,這樣可以把數組 x 看成一個 1 : n 的整數到 x[1] , x[2] , . . . , x[n] 的一個映射表 , 其中 n 是 x 的長度。 比如,某商店有三種禮品,編號為 1,2,3 ,價格分別為 68, 88 和 168 。令

price.map <- c(68, 88, 168)

設某個收銀員在一天內分別售出禮品編號為 3,2,1,1,2,2,3 ,可以用如下的映射方式獲得售出的這些禮品對應的價格:

items <- c(3,2,1,1,2,2,3)
y <- price.map[items]
print(y)

返回:

R語言向量下標和子集怎么用

R 向量可以用字符型向量作下標,字符型下標也允許重復,所以可以把帶有元素名的 R 向量看成是元素名到元素值的映射表。 比如,設 sex 為 10 個學生的性別(男、女)

sex <- c(" 男", " 男", " 女", " 女", " 男", " 女", " 女", " 女", " 女", " 男")

希望把每個學生按照性別分別對應到藍色和紅色。首先建立一個 R 向量當作映射

sex.color <- c(' 男'='blue', ' 女'='red')

用 R 向量 sex.color 當作映射,可以獲得每個學生對應的顏色

cols <- sex.color[sex]; print(cols)

返回:

R語言向量下標和子集怎么用

這樣的映射結果中帶有不必要的元素名,用 unname() 函數可以去掉元素名,如

unname(cols)

返回:

R語言向量下標和子集怎么用

9.集合運算

可以把向量 x 看成一個集合,但是其中的元素允許有重復。用 unique(x) 可以獲得 x 的所有不同值。如

unique(c(1, 5, 2, 5))

返回:

R語言向量下標和子集怎么用

 用 a %in% x 判斷 a 的每個元素是否屬于向量 x,如

5 %in% c(1,5,2)

返回:

R語言向量下標和子集怎么用

c(5,6) %in% c(1,5,2)

返回

R語言向量下標和子集怎么用

%in 運算符類似,函數 match(x, table) 對向量 x 的每個元素,從向量 table 中查找其首次出現位置并返回這些位置。沒有匹配到的元素位置返回NA_integer_( 整數型缺失值) 。如

 一個數值判斷:

match(5, c(1,5,2))

返回:

R語言向量下標和子集怎么用

若所匹配集合有重復元素,則返回為第一個元素的下標:

match(5, c(1,5,2,5))

返回:

R語言向量下標和子集怎么用

 若匹配兩個元素的所屬呢?

match(c(2,5), c(1,5,2,5))

返回:

R語言向量下標和子集怎么用

 若所匹配元素中,有集合中沒有的呢?則返回空值,如

match(c(2,5,0), c(1,5,2,5))

返回:

R語言向量下標和子集怎么用

 用 intersect(x,y)交集,結果中不含重復元素,如

intersect(c(5, 7), c(1, 5, 2, 5))

返回:

R語言向量下標和子集怎么用

union(x,y) 并集,結果中不含重復元素,如

union(c(5, 7), c(1, 5, 2, 5))

返回:

R語言向量下標和子集怎么用

  用 setdiff(x,y) 差集,即 x 的元素中不屬于 y 的元素組成的集合,結果中不含重復元素,如

setdiff(c(5, 7), c(1, 5, 2, 5))

 返回:

R語言向量下標和子集怎么用

 用 setequal(x,y) 判斷兩個集合是否相等,不受次序與重復元素的影響,如

setequal(c(1,5,2), c(2,5,1))

R語言向量下標和子集怎么用

 再如

setequal(c(1,5,2), c(2,5,1,5))

返回:

R語言向量下標和子集怎么用

練習 

設文件 class.csv 內容如下 :
name,sex,age,height,weight
Alice,F,13,56.5,84
Becka,F,13,65.3,98
Gail,F,14,64.3,90
Karen,F,12,56.3,77
Kathy,F,12,59.8,84.5
Mary,F,15,66.5,112
Sandy,F,11,51.3,50.5
Sharon,F,15,62.5,112.5
Tammy,F,14,62.8,102.5
Alfred,M,14,69,112.5
Duke,M,14,63.5,102.5
Guido,M,15,67,133
James,M,12,57.3,83
Jeffrey,M,13,62.5,84
John,M,12,59,99.5
Philip,M,16,72,150
Robert,M,12,64.8,128
Thomas,M,11,57.5,85
William,M,15,66.5,112
用如下程序可以把上述文件讀入為 R 數據框 d.class, 并取出其中的 name 和
age 列到變量 name 和 age 中:
d.class <- read.csv ( 'class.csv' , header= TRUE , stringsAsFactors= FALSE )
name <- d.class[, 'name' ]
age <- d.class[, 'age' ]
(1) 求出 age 中第 3, 5, 7 號的值;
(2) 用變量 age, 求出達到 15 歲及以上的那些值;
(3) 用變量 name 和 age, 求出 Mary 與 James 的年齡。
(4) 求 age 中除 Mary 與 James 這兩人之外的那些人的年齡值,保存到變量 age1 中。
(5) 假設向量 x 長度為 n , 其元素是 { 1 , 2 , . . . , n } 的一個重排。可以把 x 看成一個 i 到 x[i] 的映射 (i 在 { 1 , 2 , . . . , n } 中取值 ) 。求向量 y, 保存了上述映射的逆映射,即:如果 x[i]=j, 則 y[j]=i 。

關于“R語言向量下標和子集怎么用”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

万州区| 无棣县| 云南省| 绥宁县| 房产| 沙洋县| 马关县| 蓬安县| 纳雍县| 平顶山市| 宝兴县| 涪陵区| 东丰县| 滁州市| 克什克腾旗| 大城县| 忻城县| 灵石县| 临邑县| 景泰县| 防城港市| 股票| 开化县| 阳谷县| 长寿区| 亚东县| 任丘市| 西城区| 中西区| 兰州市| 寿阳县| 陵水| 梁平县| 临颍县| 阳新县| 济阳县| 衢州市| 历史| 松滋市| 高青县| 富蕴县|