当前位置: 首页 > news >正文

python面向过程、面向对象

文章目录

  • 1、前言
  • 2、面向过程 OPP
  • 3、面向对象 OOP
  • 4、参考

1、前言

  考虑这样一个问题,500个小孩围城一,从第一个小孩开始计数,逢三出圈(逢三:代表能被三整除,如6、27、468),使用python面向过程和面向对象进行编程解答。

2、面向过程 OPP

# 定义500个孩子
cycle = list(range(1, 501))
step = 1
while len(cycle) > 1:dels = []for kid in cycle:if step % 3 == 0:dels.append(kid)step +=1cycle = [i for i in cycle if i not in dels]print(cycle)		

3、面向对象 OOP

在这里插入图片描述
在这里插入图片描述

class Kid:def __init__(self, gid):self.gid = gidself.left = Noneself.right = Noneclass Cycle:def __init__(self, n):self.head = Noneself.tail = Nonefor i in range(1, n + 1):self.add(Kid(i))def add(self, kid): """ 向圈中添加一个小孩 """if self.head is None and self.tail is None:""" 如果圈中还没有小孩,则将第一个小孩作为头和尾 """self.head = kidself.tail = kidkid.left = kidkid.right = kidelse:""" 如果圈中已经有小孩,则将新小孩添加到尾部的右边 """kid.left = self.headkid.right = self.tailself.head.right = kidself.tail.left = kidself.tail = kiddef remove(self, kid):""" 从圈中移除一个小孩 """if kid is self.head:""" 如果移除的是头,则将下一个小孩作为头 """self.head = kid.leftif kid is self.tail:""" 如果移除的是尾,则将上一个小孩作为尾 """self.tail = kid.right""" 将移除的小孩的左右小孩连接起来 """kid.left.right = kid.rightkid.right.left = kid.leftkid.left = Nonekid.right = Nonecycle = Cycle(500)
cur = cycle.head
step = 1
while cycle.head is not cycle.tail:cur = cur.leftif step % 3 == 0:cycle.remove(cur.right)step += 1print(cycle.head.gid)

4、参考

Python一个例子理解面向对象和面向过程的差别


http://www.mrgr.cn/news/19824.html

相关文章:

  • p2p、分布式,区块链笔记(IPFS): 论文Merkle-CRDTs : Merkle-DAGs meet CRDTs
  • Java类和对象之构造方法与对象创建之计算数学中的分数值
  • chapter2_逻辑代数基础
  • 2024 NOIP 初赛复习计划
  • 探索Python中的Ellipsis:不仅仅是三个点
  • MySQL 的基础 一 (连接池, SQL接口, 查询解析器, 查询优化器, 存储引擎接口, 执行器)
  • 跟李沐学AI:循环神经网络RNN
  • LeetCode 算法:完全平方数 c++
  • 稳压二极管
  • APP攻防-资产收集篇FridaHOOKXposed证书提取单向双向检验抓包mobsf
  • 分享——有趣的题目
  • 皮尔逊相关系数
  • 第4章-01-学会从Chrome浏览器中Network
  • Spring Boot之Actuator介绍
  • 实战赢家:为何传统边缘分割方法比深度学习更有效?附源码+教学+数据
  • 节日庆典中的白酒文化,传承与创新并存
  • echarts三维立体扇形图+三维立体环形图配置详解记录
  • 硬件驱动misc简介
  • 注意力机制
  • js运算符---自增++自减--运算符