【DataStructure In Python】Python模拟链表
最近一直在学习Python和Perl这两门语言,两者共同点很多,也有不多。希望通过这样的模拟练习可以让自己更熟悉语言,虽然很多时候觉得这样用Python或者Perl并没有体现这两者的真正价值。
#! /usr/bin/env python
# DataStructure Linkedlist class Node:
"""
Member Variable:
1. next
2. data
"""
def __init__(self, data):
self.data = data
self.next = None def __str__(self):
return "NodeInfo: data=%d, next_id=%d" % (self.data, id(self.next)) class LinkedList:
"""
Member Variable:
1.head
2.cur
"""
def __init__(self):
self.head = Node(0)
self.cur = self.head; def __init__(self, data=None):
if data is not None:
self.head = Node(1)
newNode = Node(data)
self.head.next = newNode
self.cur = self.head.next
else :
self.head = Node(0)
self.cur = self.head; def __str__(self):
tmp = "The List has %d nodes.\n" % self.head.data
Nodetmp = self.head.next
while Nodetmp is not None:
tmp += "->%d" % Nodetmp.data
Nodetmp = Nodetmp.next
return tmp def Insert(self, data, pos=-1):
if pos > self.head.data :
print "Out of range"
return
newNode = Node(data)
if pos >= 0:
Nodetmp = self.head.ext
while pos :
Nodetmp = Nodetmp.Next
pos -= 1
newNode.next = Nodetmp.next
Nodetmp.next = newNode
else:
self.cur.next = newNode
self.cur = self.cur.next
self.head.data += 1 def Remove(self, data, pos=0):
if pos >= self.head.data :
print "Out of range"
return
Nodetmp = self.head
beg = pos
while pos >= 1:
Nodetmp = Nodetmp.next
pos -= 1
while Nodetmp.next is not None:
if Nodetmp.next.data == data :
break
Nodetmp = Nodetmp.next
Nodetmp.next = Nodetmp.next.next
self.head.data -= 1
if beg == self.head.data :
self.cur = Nodetmp.next def Find(self, data, pos=0):
if pos > self.head.data:
print "Out of range"
return
Nodetmp = self.head
while pos :
Nodetmp = Nodetmp.next
pos -= 1
while Nodetmp.next is not None:
if Nodetmp.data == data :
break
Nodetmp = Nodetmp.next
return Nodetmp def GetLinkSize(self):
return self.head.data if __name__ == "__main__" :
Lst = LinkedList()
for i in range(10) :
Lst.Insert(i)
for i in range(1,10,2) :
Lst.Insert(i)
print Lst
tmp = Lst.Find(3, 10)
print tmp.next
Lst.Remove(1, 10)
print Lst
Lst.Insert(4)
print Lst
运行截图如下。
【DataStructure In Python】Python模拟链表的更多相关文章
- 用python实现模拟登录人人网
用python实现模拟登录人人网 字数4068 阅读1762 评论19 喜欢46 我决定从头说起.懂的人可以快速略过前面理论看最后几张图. web基础知识 从OSI参考模型(从低到高:物理层,数据链路 ...
- python数据结构之链表(一)
数据结构是计算机科学必须掌握的一门学问,之前很多的教材都是用C语言实现链表,因为c有指针,可以很方便的控制内存,很方便就实现链表,其他的语言,则没那么方便,有很多都是用模拟链表,不过这次,我不是用模拟 ...
- Python requests模拟登录
Python requests模拟登录 #!/usr/bin/env python # encoding: UTF-8 import json import requests # 跟urllib,ur ...
- python urllib2 模拟网站登陆
python urllib2 模拟网站登陆 1. 可用浏览器先登陆,然后查看网页源码,分析登录表单 2. 使用python urllib2,cookielib 模拟网页登录 import urllib ...
- Python实现模拟登陆
大家经常会用Python进行数据挖掘的说,但是有些网站是需要登陆才能看到内容的,那怎么用Python实现模拟登陆呢?其实网路上关于这方面的描述很多,不过前些日子遇到了一个需要cookie才能登陆的网站 ...
- Python中模拟enum枚举类型的5种方法分享
这篇文章主要介绍了Python中模拟enum枚举类型的5种方法分享,本文直接给出实现代码,需要的朋友可以参考下 以下几种方法来模拟enum:(感觉方法一简单实用) 复制代码代码如下: # way1 ...
- 【小白学爬虫连载(10)】–如何用Python实现模拟登陆网站
Python如何实现模拟登陆爬取Python实现模拟登陆的方式简单来说有三种:一.采用post请求提交表单的方式实现.二.利用浏览器登陆网站记录登陆成功后的cookies,采用get的请求方式,传入c ...
- python 怎么模拟加header(如User-Agent、Content-Type等等)
# -*- coding: cp936 -*- #python 27 #xiaodeng #python 怎么模拟加header(如User-Agent.Content-Type等等) #办法一: i ...
- python爬虫模拟登陆
python爬虫模拟登陆 学习了:https://www.cnblogs.com/chenxiaohan/p/7654667.html 用的这个 学习了:https://www.cnblogs.co ...
- 【爬虫】python requests模拟登录知乎
需求:模拟登录知乎,因为知乎首页需要登录才可以查看,所以想爬知乎上的内容首先需要登录,那么问题来了,怎么用python进行模拟登录以及会遇到哪些问题? 前期准备: 环境:ubuntu,python2. ...
随机推荐
- XCode实用好用插件集锦
工欲善其事,必先利其器,iOS开发运用插件可以大大提高开发的效率. 原文地址: http://www.oschina.net/project/tag/432/xcode-plugins
- GNU iconv
GNU iconv 一.关键函数 1.iconv_open() iconv_open(DestinationCharsets, SourceCharSets) 2.iconv() [XSI] [Opt ...
- Struts2文件下载浅析
Struts2极大的简化了文件上传和下载,本文将主要介绍一下Struts2文件下载的实现1.功能主要是,在下载页面点击下载后,则下载相应的文件 2.代码部分jsp页面downloadPage:< ...
- RX学习笔记:JavaScript数组操作
RX学习笔记:JavaScript数组操作 2016-07-03 增删元素 unshift() 在数组开关添加元素 array.unshift("value"); array.un ...
- PHP知识分享之session && cookie
<?php /* * @Content : session && cookie * @author : Mr.xml * @time : 2015-3-17 09:53:49 * ...
- MVC文件上传 - 使用jquery异步上传并客户端验证类型和大小
本篇体验MVC上传文件,从表单上传过渡到jquery异步上传. MVC最基本的上传文件是通过form表单提交方式 □ 前台视图部分 <% using(Html.BeginForm("F ...
- javascripct数组
定义数组 数组对象用来在单独的变量名中存储一系列的值. 我们使用关键词 new 来创建数组对象.下面的代码定义了一个名为 myArray 的数组对象: var myArray=new Array() ...
- apache设置映射文件夹的配置方法
在apache的配置文件中加入以下配置 Alias /uploadImage F:/upload <Directory F:/upload/UploadFiles> Option ...
- objective-c常用数学方法
1. 三角函数 double sin (double);正弦 double cos (double);余弦 double tan (double);正切 2 .反三角函数 double as ...
- GC的代机制
1.代为CLR垃圾回收器采用的一种机制,基于以下几点假设:对象越新,生存期越短:对象越老,生存期越长: 2.托管堆仅支持3代(GC.MaxGeneration,第0代.第1代.第2代),CLR初始化会 ...