zoukankan      html  css  js  c++  java
  • 自定义N维空间数组

    class Space : IEnumerable<Space> {
        public object Filler {
            get {
                return filler ?? (filler = Top.create());
            }
        }
        public Space Upper { get; protected set; }
        public Space Top => Upper?.Top ?? this;
    
        private Func<object> create;
        private object filler;
        public int[] Chain { get; set; }
        public int[] Dementions { get; }
        Space[] all;
    
        static Random r { get; } = new Random();
    
        public Space(int i, params int[] indexes) : this(() => r.Next(2), i, indexes) { }
    
        public Space(Func<object> create, int i, params int[] indexes) : this(new int[0], new[] { i }.Concat(indexes).ToArray()) {
            this.create = create;
        }
    
        private Space(int[] chain, params int[] indexes) {
            Chain = chain;
            Dementions = indexes;
            var i = indexes[0];
            all = new Space[i];
            var chains = Enumerable.Range(0, i).Select(e => chain.Concat(new int[] { e }).ToArray()).ToArray();
            if (indexes.Length == 1) {
                while (i-- > 0) {
                    all[i] = new Space(chains[i]);
                    all[i].Upper = this;
                }
            } else {
                var _indexes = indexes.Skip(1).ToArray();
                while (i-- > 0) {
                    all[i] = new Space(chains[i], _indexes);
                    all[i].Upper = this;
                }
            }
            filler = all;
        }
    
        private Space(int[] chain) {
            Chain = chain;
        }
    
        public Space this[int i, params int[] indexes] {
            get {
                if (all == null) {
                    return (Filler as Space)?[i, indexes];
                }
                if (indexes.Length == 0) {
                    return all[i];
                }
                return all[i][indexes[0], indexes.Skip(1).ToArray()];
            }
        }
    
        public override string ToString() {
            return all?.Aggregate(string.Empty, (a, s) => a + s + ',').Trim(',') ?? Filler.ToString();
        }
    
        public override bool Equals(object obj) {
            if (GetType() != obj?.GetType()) {
                return false;
            }
            return GetHashCode() == obj.GetHashCode();
        }
    
        public override int GetHashCode() {
            if (Upper == null) {
                return base.GetHashCode();
            }
            return Top.GetHashCode() - Chain.GetHashCode();
        }
    
        public IEnumerator<Space> GetEnumerator() {
            return ((IEnumerable<Space>)all).GetEnumerator();
        }
    
        IEnumerator IEnumerable.GetEnumerator() {
            return ((IEnumerable<Space>)all).GetEnumerator();
        }
    }
  • 相关阅读:
    tcpreplay安装使用经验
    Linux 性能优化之 IO 子系统 系列 图
    深入理解Fsync----JBD内核调试 专业打杂程序员 @github yy哥
    LINUX 文件系统JBD ----深入理解Fsync
    通过查看mysql 配置参数、状态来优化你的mysql
    linux IO 内核参数调优 之 原理和参数介绍
    Mysql参数详解
    Mysql show Status参数详解
    MYSQL: Handler_read_%参数说明
    mysql的优化措施,从sql优化做起
  • 原文地址:https://www.cnblogs.com/ly45/p/6083420.html
Copyright © 2011-2022 走看看