python day3

p33

1 列表的创建:
 >>> a = [0,1,2,3,"day"]
>>> a[0]
0
>>> a[3]
3
>>> a[4]
'day'
>>> 

2  用list 转化成列表:
>>> a = list(range(10))
>>> a
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> a = list("renshanwen")
>>> a
['r', 'e', 'n', 's', 'h', 'a', 'n', 'w', 'e', 'n']
>>> 

3  通过range() 创建整数列表:
range([start],[end],[step])
注意:range 返回的是range对象,不是列表。需要用list()方法将其转化成列表。
例如:
>>> list(range(3,15,2))
[3, 5, 7, 9, 11, 13]
>>> list(range(15,3,-1))
[15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4]

4 推导式生成列表:
>>> a = [x*2 for x in range(5)]
>>> a
[0, 2, 4, 6, 8]
>>> a = [x*2 for x in range(100) if x%9==0]
>>> a
[0, 18, 36, 54, 72, 90, 108, 126, 144, 162, 180, 198]

p34

1列表元素的增加和删除:
append()方法:
>>> a = [20,30]
>>> a.append(40)
>>> a
[20, 30, 40]

+:
>>> a=[20,40]
>>> id(a)
69048720
>>> a = a+[50]
>>> a
[20, 40, 50]
>>> id(a)
59868944
注:两者的区别在于,后者的存储地址发生了改变。

extend()方法:
>>> a = [20,40]
>>> id(a)
69048720
>>> a.extend([50])
>>> a
[20, 40, 50]
>>> id(a)
69048720
>>> 

2 元素的插入:
>>> a = [20,30,40,50]
>>> a.insert(2,100)
>>> a
[20, 30, 100, 40, 50]
>>> 

3  乘法扩展:
>>> a = ['sxt',100]
>>> b = a*3
>>> a
['sxt', 100]
>>> b
['sxt', 100, 'sxt', 100, 'sxt', 100]
>>> 

p35:

del删除:
>>> a = [100,200,300]
>>> del a[1]
>>> a
[100, 300]

pop删除:
>>> a = [10,20,30,40]
>>> a.pop()
40
>>> a
[10, 20, 30]
>>> a.pop(0)
10
>>> a
[20, 30]
>>> 

remove :删除首次出现的元素:
>>> a = [10,20,10,30,10,40]
>>> a.remove(10)
>>> a
[20, 10, 30, 10, 40]
>>> 

p36

列表元素的访问和计数:
index()获取指定元素首次出现的时候的索引:
格式: index(值,[start],[end])
>>> a = [10,20,30,40,50,60]
>>> a.index(30,2)
2
>>> a.index(30,3)
Traceback (most recent call last):
  File "<pyshell#59>", line 1, in <module>
    a.index(30,3)
ValueError: 30 is not in list
>>> a.index(30,-1)
Traceback (most recent call last):
  File "<pyshell#60>", line 1, in <module>
    a.index(30,-1)
ValueError: 30 is not in list
>>> a.index(30,0,2)
Traceback (most recent call last):
  File "<pyshell#61>", line 1, in <module>
    a.index(30,0,2)
ValueError: 30 is not in list
>>> a.index(30,0,4)
2
>>> 

count() :获得次数:
>>> a = [10,10,10,20,10]
>>> a.count()
Traceback (most recent call last):
  File "<pyshell#65>", line 1, in <module>
    a.count()
TypeError: count() takes exactly one argument (0 given)
>>> a.count(10)
4


len():获取长度:
>>> 
>>> a = [10,10,10,20,10]
>>> len(a)
5


判断元素是否存在??
>>> a = [10,20,39,49]
>>> 10 in a
True
>>> 30 in a
False
>>> 

p37:

切片操作:
>>> a = [10,20,30,40,50,60]
>>> a[:]
[10, 20, 30, 40, 50, 60]
>>> a[1:3:1]
[20, 30]
>>> a[1:5:2]
[20, 40]
>>> 

列表的遍历:
>>> a = [1,2,3,4,5,6,2]
>>> for x in a:
	print(x)	
1
2
3
4
5
6
2
>>> 


复制列表的所有信息:
>>> list1 = [1,2,3,4]
>>> list2 = list1
>>> list2
[1, 2, 3, 4]
>>> 

p38:

列表排序:

1.修改原列表,不生成新列表:
>>> a = [3,2,4,5,1]
>>> a.sort()
>>> a
[1, 2, 3, 4, 5]
>>> a.sort(reverse=True)
>>> a
[5, 4, 3, 2, 1]
>>> 

2.建立新列表排序:

>>> a = [2,3,1,4,2,5]
>>> a = sorted(a)
>>> a
[1, 2, 2, 3, 4, 5]
>>> a = sorted(a,reverse=True)
>>> a
[5, 4, 3, 2, 2, 1]
>>> 

reverse()迭代器的用法:
>>> a = [20,10,30,40]
>>> a[::-1]
[40, 30, 10, 20]
>>> a = reversed(a)
>>> a
<list_reverseiterator object at 0x03598690>
>>> list(a)
[40, 30, 10, 20]
>>> 


max  min  返回最大值和最小值:
sum 求和:
>>> a = [10,20,3,40,60]
>>> min(a)
3
>>> max(a)
60
>>> sum(a)
133

p39


二维数组::

>>> a=[
	[1,2,3],
	[4,5,6],
	[7,8,9],
      ]
>>> a
[[1, 2, 3], [4, 5, 6], [7, 8, 9]]
>>> a[1][2]
6






内容概要:本文介绍了一种基于蒙特卡洛模拟和拉格朗日优化方法的电动汽车充电站有序充电调度策略,重点针对分时电价机制下的分散式优化问题。通过Matlab代码实现,构建了考虑用户充电需求、电网负荷平衡及电价波动的数学模【电动汽车充电站有序充电调度的分散式优化】基于蒙特卡诺和拉格朗日的电动汽车优化调度(分时电价调度)(Matlab代码实现)型,采用拉格朗日乘子法处理约束条件,结合蒙特卡洛方法模拟大量电动汽车的随机充电行为,实现对充电功率和时间的优化分配,旨在降低用户充电成本、平抑电网峰谷差并提升充电站运营效率。该方法体现了智能优化算法在电力系统调度中的实际应用价值。; 适合人群:具备一定电力系统基础知识和Matlab编程能力的研究生、科研人员及从事新能源汽车、智能电网相关领域的工程技术人员。; 使用场景及目标:①研究电动汽车有序充电调度策略的设计与仿真;②学习蒙特卡洛模拟与拉格朗日优化在能源系统中的联合应用;③掌握基于分时电价的需求响应优化建模方法;④为微电网、充电站运营管理提供技术支持和决策参考。; 阅读建议:建议读者结合Matlab代码深入理解算法实现细节,重点关注目标函数构建、约束条件处理及优化求解过程,可尝试调整参数设置以观察不同场景下的调度效果,进一步拓展至多目标优化或多类型负荷协调调度的研究。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

StanwenRen

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值