目录
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.今天中午吃什么
烤肉拌饭或者小杨生煎