当前位置:首页 » 《关注互联网》 » 正文

kotlin中list的创建、元素添加、统计元素个数、寻找峰值点_WangNning2000的博客

8 人参与  2021年09月02日 11:03  分类 : 《关注互联网》  评论

点击全文阅读


目录

1.创建list

2.添加元素

3.统计元素的个数

4.找list内峰值点

5.今天中午吃什么


上周在python翻译kotlin的过程中,在list相关部分遇到的一些小问题,这一部分想要实现的功能是:

将随着时间生成的一个一个的整数,存为一个  [12,21,2,24,54,23,……] 形式的矩阵,并找到其中的峰值点。

主要涉及到一下几个问题:

1.创建list;

2.添加元素;

3.统计元素个数;

4.找list内峰值点;

1.创建list

创建可变list,使用mutableListOf()

(注意:listOf()用于创建没有元素的空List)

val signal = mutableListOf<Int>()

 注意:因为是随着时间而产生的一系列整数,所以空list的定义应该放在循环外(我直接定义在class下边了),否则到最后signal只有一个值,也就是最后产生的那个值。

2.添加元素

向signal中添加h,这里要做的就是每生成一个新的h就存入signal中。

signal.add(h)

(注意:此处的h就是随着时间推进,每一帧产生的一个新的整数,如果单独输出h的话,是这样的形式:

[12]

[21]

[2]

[24]

……)

3.统计元素的个数

list元素的个数,即list的长度。

signal.size

4.找list内峰值点

当前判断的值大于前边的且小于后边的即为极值点,为了限制噪声波动,限制高于阈值thre才算做极值。

(注意:后边为了避免一个峰内出现几个峰尖而导致判别为多个峰,可以限定峰的宽度,认为该宽度内只存在一个峰)

        for (i in 1 until lengthData - 1) {
            if((signal[i-1]<signal[i]) and (signal[i] > signal[i+1]) and (signal[i]>thre)){
                l.add(i)  //找出极值的位置
            }
            if(signal[i] == signal[i-1] ){  //最高点前后可能有相等的情况
                l.add(i)
            }
        }

5.今天中午吃什么

烤肉拌饭或者小杨生煎


点击全文阅读


本文链接:http://zhangshiyu.com/post/26809.html

元素  峰值  极值  
<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

关于我们 | 我要投稿 | 免责申明

Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1