最近一直在学习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模拟链表的更多相关文章

  1. 用python实现模拟登录人人网

    用python实现模拟登录人人网 字数4068 阅读1762 评论19 喜欢46 我决定从头说起.懂的人可以快速略过前面理论看最后几张图. web基础知识 从OSI参考模型(从低到高:物理层,数据链路 ...

  2. python数据结构之链表(一)

    数据结构是计算机科学必须掌握的一门学问,之前很多的教材都是用C语言实现链表,因为c有指针,可以很方便的控制内存,很方便就实现链表,其他的语言,则没那么方便,有很多都是用模拟链表,不过这次,我不是用模拟 ...

  3. Python requests模拟登录

    Python requests模拟登录 #!/usr/bin/env python # encoding: UTF-8 import json import requests # 跟urllib,ur ...

  4. python urllib2 模拟网站登陆

    python urllib2 模拟网站登陆 1. 可用浏览器先登陆,然后查看网页源码,分析登录表单 2. 使用python urllib2,cookielib 模拟网页登录 import urllib ...

  5. Python实现模拟登陆

    大家经常会用Python进行数据挖掘的说,但是有些网站是需要登陆才能看到内容的,那怎么用Python实现模拟登陆呢?其实网路上关于这方面的描述很多,不过前些日子遇到了一个需要cookie才能登陆的网站 ...

  6. Python中模拟enum枚举类型的5种方法分享

    这篇文章主要介绍了Python中模拟enum枚举类型的5种方法分享,本文直接给出实现代码,需要的朋友可以参考下   以下几种方法来模拟enum:(感觉方法一简单实用) 复制代码代码如下: # way1 ...

  7. 【小白学爬虫连载(10)】–如何用Python实现模拟登陆网站

    Python如何实现模拟登陆爬取Python实现模拟登陆的方式简单来说有三种:一.采用post请求提交表单的方式实现.二.利用浏览器登陆网站记录登陆成功后的cookies,采用get的请求方式,传入c ...

  8. python 怎么模拟加header(如User-Agent、Content-Type等等)

    # -*- coding: cp936 -*- #python 27 #xiaodeng #python 怎么模拟加header(如User-Agent.Content-Type等等) #办法一: i ...

  9. python爬虫模拟登陆

    python爬虫模拟登陆 学习了:https://www.cnblogs.com/chenxiaohan/p/7654667.html  用的这个 学习了:https://www.cnblogs.co ...

  10. 【爬虫】python requests模拟登录知乎

    需求:模拟登录知乎,因为知乎首页需要登录才可以查看,所以想爬知乎上的内容首先需要登录,那么问题来了,怎么用python进行模拟登录以及会遇到哪些问题? 前期准备: 环境:ubuntu,python2. ...

随机推荐

  1. XCode实用好用插件集锦

    工欲善其事,必先利其器,iOS开发运用插件可以大大提高开发的效率. 原文地址: http://www.oschina.net/project/tag/432/xcode-plugins

  2. GNU iconv

    GNU iconv 一.关键函数 1.iconv_open() iconv_open(DestinationCharsets, SourceCharSets) 2.iconv() [XSI] [Opt ...

  3. Struts2文件下载浅析

    Struts2极大的简化了文件上传和下载,本文将主要介绍一下Struts2文件下载的实现1.功能主要是,在下载页面点击下载后,则下载相应的文件 2.代码部分jsp页面downloadPage:< ...

  4. RX学习笔记:JavaScript数组操作

    RX学习笔记:JavaScript数组操作 2016-07-03 增删元素 unshift() 在数组开关添加元素 array.unshift("value"); array.un ...

  5. PHP知识分享之session && cookie

    <?php /* * @Content : session && cookie * @author : Mr.xml * @time : 2015-3-17 09:53:49 * ...

  6. MVC文件上传 - 使用jquery异步上传并客户端验证类型和大小

    本篇体验MVC上传文件,从表单上传过渡到jquery异步上传. MVC最基本的上传文件是通过form表单提交方式 □ 前台视图部分 <% using(Html.BeginForm("F ...

  7. javascripct数组

    定义数组 数组对象用来在单独的变量名中存储一系列的值. 我们使用关键词 new 来创建数组对象.下面的代码定义了一个名为 myArray 的数组对象: var myArray=new Array() ...

  8. apache设置映射文件夹的配置方法

    在apache的配置文件中加入以下配置 Alias /uploadImage F:/upload <Directory F:/upload/UploadFiles>      Option ...

  9. objective-c常用数学方法

    1. 三角函数  double sin (double);正弦  double cos (double);余弦  double tan (double);正切  2 .反三角函数  double as ...

  10. GC的代机制

    1.代为CLR垃圾回收器采用的一种机制,基于以下几点假设:对象越新,生存期越短:对象越老,生存期越长: 2.托管堆仅支持3代(GC.MaxGeneration,第0代.第1代.第2代),CLR初始化会 ...