zoukankan      html  css  js  c++  java
  • 用C#实现链表

    using System;
    using System.Collections;
    using System.Collections.Generic;

    namespace 数据结构与算法
    {
    public class Base_Manager<T> where T : new() //泛型单例模式基类
    {
    private static T instance;
    public static T GetInastance()
    {
    if (instance == null)
    {
    instance = new T();
    }
    return instance;
    }
    }
    class Program
    {
    static void Main(string[] args)
    {
    Node node1 = new Node("once");
    Node node2 = new Node("upon");
    LinkedList linkedList = new LinkedList(node1);
    node1.next_node = node2;
    linkedList.insert_at_index(0, "second");
    Console.WriteLine(linkedList.index_of("upon").ToString());
    Console.ReadLine();
    }
    }
    /* 实现链表包含两个类 Node和LinkedLlist */
    class Node
    {
    public object data;
    public Node next_node;
    public Node(object data_value)
    {
    data = data_value;
    }
    }
    class LinkedList
    {
    public Node first_node;
    Node current_node, new_node,deleted_node;
    int current_index = 0;
    public LinkedList(Node firstnode_value)
    {
    first_node = firstnode_value;
    }
    public object read(int index) //读取某个索引
    {
    current_node = first_node;
    current_index = 0;
    while (current_index < index)
    {
    if (current_node.next_node == null)
    {
    return "所找索引不在链表中";
    }
    current_node = current_node.next_node;
    current_index++;
    }
    return current_node.data;
    }
    public object index_of(object value) //查找某个值的索引
    {
    current_node = first_node;
    current_index = 0;
    while (current_node != null)
    {
    if (current_node.data == value)
    {
    return current_index;
    }
    current_node = current_node.next_node;
    current_index++;
    }
    return "遍历链表没有找到这个数据";
    }
    public void insert_at_index(int index,object value) //插入到链表里面
    {
    new_node = new Node(value);
    if (index == 0)
    {
    new_node.next_node = first_node;
    first_node = new_node;
    return;
    }
    current_node = first_node;
    current_index = 0;
    int prev_index = index - 1;
    while (current_index < prev_index)
    {
    current_node = current_node.next_node;
    current_index++;
    }
    new_node.next_node = current_node.next_node;
    current_node.next_node = new_node;
    }
    public object delete_at_index(int index) //按索引删除
    {
    if (index == 0)
    {
    deleted_node = first_node;
    first_node = first_node.next_node;
    return deleted_node;
    }
    current_node = first_node;
    current_index = 0;
    while (current_index < index - 1)
    {
    current_node = current_node.next_node;
    current_index++;
    }
    deleted_node = current_node.next_node;
    current_node.next_node = deleted_node.next_node;
    return 0;
    }
    }
    }

  • 相关阅读:
    PHP配置文件处理类
    PHP中实现图片上传的类库
    在PHP中实现StringBuilder类
    微软官方及第三方SDK http://msdn.microsoft.com/zhcn/jj923044
    在PHP中模拟asp的response类
    Atitit.并发测试解决方案(2) 获取随机数据库记录 随机抽取数据 随机排序 原理and实现
    atitit. access token是什么??微信平台公众号开发access_token and Web session保持状态机制
    atitit.二进制数据无损转字符串网络传输
    atitit.重装系统需要备份的资料总结 o84..
    atitit.web ui 结构建模工具总结
  • 原文地址:https://www.cnblogs.com/wei1349/p/13877705.html
Copyright © 2011-2022 走看看