楼主: pennyr617
1148 1

[问答] R提取向量中连续相等的数值 [推广有奖]

  • 0关注
  • 0粉丝

本科生

98%

还不是VIP/贵宾

-

威望
0
论坛币
841 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
837 点
帖子
51
精华
0
在线时间
143 小时
注册时间
2012-3-31
最后登录
2023-12-4

楼主
pennyr617 发表于 2020-3-31 09:41:58 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
现有一个向量1,2,3,3,3,3,2,1,5,5,5,2,2,2,2,2 如何编写R代码提取出向量中连续相等的4个及4个以上元素?
如这个例子中得到的结果应为3,3,3,3,2,2,2,2,2
求大神代码,紧急在线等,万分感谢!!!
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝


沙发
rosenbloog 发表于 2020-3-31 22:19:40
  1. seq3 = c(1,2,3,3,3,3,2,1,5,5,5,2,2,2,2,2)

  2. # 关键函数:?rle
  3. runs = rle(seq3)
  4. runs

  5. myruns = which(runs$lengths >= 4)

  6. runs.lengths.cumsum = cumsum(runs$lengths)
  7. ends = runs.lengths.cumsum[myruns]

  8. newindex = ifelse(myruns>1, myruns-1, 0)
  9. starts = runs.lengths.cumsum[newindex] + 1
  10. if (0 %in% newindex) starts = c(1,starts)

  11. print(starts)
  12. print(ends)

  13. print(seq3[starts[1]:ends[1]])
  14. print(seq3[starts[2]:ends[2]])
复制代码
参考:https://masterr.org/r/how-to-find-consecutive-repeats-in-r/

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2026-1-15 13:50