数据驱动型的设计02

本系列从数据结构相关的计算机知识出发,从数据的角度提出一些数据驱动的设计思维模式。

第01期总体介绍数据结构与设计的关系,用数据结构的方式来思考设计,并通过几个案例介绍一些大的思路。

第02期介绍数据结构中的链表结构,并探讨设计中可能的链表数据。

1 何为链表?

1.1 概念

一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接实现的。图示:

来个形象点的图:

1.2 链表有特点呢?

查找某个元素:需要从链表中第一个元素开始,一直找到目标元素的位置。

插入/删除某个元素:只要修改元素中的指针。

2 用代码实现一个链表结构

采用Javascript来实现一个链表结构,加深对链表的理解,Chrome浏览器打开console面板,先实现一个链表的节点。

2.1 节点

此节点保存了数据本身(value的值)及下一个节点的位置(下一个节点),输入:

class LinkedListNode {  constructor(value,next) {
   this.value = value;
   this.next = next;  }}

这里我们需要了解下ES6的class特性,下文的例子定义了一个“类”——Point,可以看到里面有一个constructor方法,这就是构造方法,主要写一些Point对象的属性,例如x和y的坐标值;而传统的方法是通过构造函数,定义并生成新对象,然后通过 prototype 属性向对象添加属性和方法。

class Point {  constructor(){
   this.x=0;
   this.y=0;    // ...  }  toString(){    // ...  }  toValue(){    // ...  }};
   
   // 等同于

function Point(){
   this.x=0;
   this.y=0;
   //...
};
   Point.prototype = {  toString(){},  toValue(){}};

2.2 链表的基本结构

主要是有两个属性,head记录的是最开始的节点,tail记录的是结尾的节点。其中由于每个节点都有一个next属性指向下一个节点,所以head记录了整条链表的节点。

class LinkedList{     constructor(){
         this.head = null;              this.tail = null;     } }

初始化一个链表结构:

var ls=new LinkedList();

2.3 添加方法

下面为链表结构的数据添加:增删改查的方法。

添加节点的方法:

append - 在结尾插入节点

prepend - 在开始插入节点

查询节点的方法:

find

删除节点的方法:

delete

2.3.1 prepend方法

添加prepend方法,图示结合代码:

LinkedList.prototype.prepend=function(value) {
   const newNode = new LinkedListNode(value,this.head);
   // 往head添加节点    this.head = newNode;
   // 如果tail为空,往tail添加此节点    
   if (!this.tail) {
        this.tail = newNode;    }    
        
   return this;   }

实验下prepend方法:

ls.prepend(0);console.log(JSON.stringify(ls,null,2));

打印出来:

{  "head": {
       "value": 0,
       "next": null  },
   "tail": {
       "value": 0,
       "next": null  }}

继续添加:

ls.prepend(1);
console.log(JSON.stringify(ls,null,2));

结果:

"{  "head": {    "value": 1,    "next": {      "value": 0,      "next": null    }  },  "tail": {    "value": 0,    "next": null  }}"

经过多次实验,会发现,head是个一层层嵌套的结构,通过head可以找到任何一个节点(按顺序),而tail永远是存储的最后一个节点。

2.3.2 append方法

为链表结构添加append方法:

LinkedList.prototype.append=function(value) {
   const newNode = new LinkedListNode(value);
 // 如果head为空,则head设为newNode    if (!this.head) {
       this.head = newNode;
       this.tail = newNode;
       return this;    }
       
  // 把新的newNode设为tail    this.tail.next = newNode;
   this.tail = newNode;
   return this;  }

实验下append方法:

ls.append(10);
console.log(JSON.stringify(ls,null,2));

2.3.3 compare方法

为了实现删除delete,我们得先实现比对两个数值是否相等的功能,相等的话返回0:

LinkedList.prototype.compare=function(a,b){
 
   if (a === b) {
       return 0;    }
   
   return a < b ? -1 : 1;};

2.3.4 delete方法

根据value值来删除节点,凡是等于目标value的节点都被删除:

LinkedList.prototype.delete=function(value) {
   let deletedNode = null;
   // head节点是否需要被删除    while (this.head && this.compare(this.head.value, value)===0) {      deletedNode = this.head;
     this.head = this.head.next;    }
     
     let currentNode = this.head;
     if (currentNode !== null) {      
     // 遍历每一个节点      while (currentNode.next) {
     if (this.compare(currentNode.next.value, value)===0) {          deletedNode = currentNode.next;          currentNode.next = currentNode.next.next;        } else {          currentNode = currentNode.next;        }      }    }
       
  // 判断tail节点是否需要删除    if (this.compare(this.tail.value, value)===0) {
         this.tail = currentNode;    }    
   
   return deletedNode;
     };

2.3.5 find方法

实现一个简单的查找方法,找到一个值等于value的节点,并返回,代码如下:

LinkedList.prototype.find=function(value) {
   let currentNode = this.head;
   
   while (currentNode) {
   
   if (value && this.compare(currentNode.value, value)===0) {
       return currentNode;      }      currentNode = currentNode.next;    }
       
   return null;  }

2.3.6 toArray方法

链表结构的数据转化为数组数据:

 LinkedList.prototype.toArray=function() {
     const nodes = [];
     let currentNode = this.head;
     while (currentNode) {          nodes.push(currentNode);          currentNode = currentNode.next;        }
     return nodes;  }

至此,我们对链表结构的数据应该已经理解得比较深刻了。接下来,我们探讨下在设计中,有哪些是可以被链表结构的数据所表示的?

赞赏的方式可以是点广告~

3 设计中的链表结构

思考下设计里,哪些元素/手法是可以被链表结构的数据表示的?我们先了解下链表结构的几种基本类型。

3.1 链表结构的几种基本类型

Singly linked list 这是最简单的链表结构:





Double Linked List 双向链表的结构:





Circular linked list循环链表的结构:





3.2 设计中的链表结构

链表本身的特点是一个节点连接着下一个节点,非常适合描述流程性,有前后关系的数据。

1)用户体验的流线

室内设计中,不同空间游线之间的关系;

展览馆的游线设计;

UX设计中页面的跳转流线;

2)设计思路的解构

景观设计中,一层层的关系,地面铺装,树池花台,乔木灌木,亭廊构架;

平面设计中,背景,主体内容,配色,布局,构图等;

更多跟设计的结合,欢迎留言补充。

参考资料:

https://en.wikipedia.org/wiki/Linked_list

-------------------------------

推荐:

数据驱动型的设计01

ML37-Baoling【mixlab共建者的故事】

继续聊技术思维与设计思维的mix

名片怎么玩?mixlab社区名片来一个

-------------------------------

活动预告:

第4期的mixlab线下活动即将在7.14号@上海举办

-------------------------------

mixlab社区介绍:

中文:无界社区

英文:mixlab

定位:去中心化、非盈利、全球化

价值观:跨界 开放 互助 学习 创新

愿景:让每个人无限可能

mixlab社区人群来源于GoogleBrain、微软、华为、阿里鲁班、腾讯、旷视、三角兽、物灵科技、众安保险、美团、360等,还有高校背景的人员,包括MIT、CMU、UoM、清华、上交大、同济等等,汇集了机器学习、自然语言处理、前端、后端、产品经理、UI设计师、建筑设计师、高校教师、CEO等,每天都会讨论跨界问题。

附一则寻人启示:昵称为 Lucas 的用户,你填写的申请表里,微信号联系不上你……

赞赏的方式可以是点广告~

(0)

相关推荐

  • LinkedList详解

    原文链接http://zhhll.icu/2021/01/04/java%E5%9F%BA%E7%A1%80/%E9%9B%86%E5%90%88/LinkedList%E8%AF%A6%E8%A7% ...

  • 面试官:兄弟,说说 ArrayList 和 LinkedList 有什么区别

    来自公众号:沉默王二 ArrayList 和 LinkedList 有什么区别,是面试官非常喜欢问的一个问题.可能大部分小伙伴和我一样,能回答出"ArrayList 是基于数组实现的,Lin ...

  • 剑指offer之二叉树的下一个结点

    剑指offer之二叉树的下一个结点

  • ​LeetCode刷题实战25:K 个一组翻转链表

    算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试.所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 ! 今天和大家 ...

  • 数据驱动型的设计04之Stack

    " 一个哥们,有次聚会说自己买了很多条iphone数据线,家里每个房间插一条,走到哪儿都能随时充电.在场的姑娘们都当成是段子笑笑就过去了,只有个细心的姑娘悄悄问他买了多少条,他说42条.现在 ...

  • 数据驱动型的设计03之Queue队列

    本系列从数据结构相关的计算机知识出发,从数据的角度提出一些数据驱动的设计思维模式. 第01期 总体介绍数据结构与设计的关系,用数据结构的方式来思考设计,并通过几个案例介绍一些大的思路. 第02期 介绍 ...

  • 数据驱动型的设计01

    本系列从数据结构相关的计算机知识出发,从数据的角度提出一些数据驱动的设计思维模式.第01期总体介绍数据结构与设计的关系,用数据结构的方式来思考设计,并通过几个案例介绍一些大的思路. 1 数据结构与设计 ...

  • 【结构设计】自攻型螺丝柱设计

    结构设计 自攻型螺丝柱设计 1 螺丝柱 螺丝柱,也称BOSS柱,是塑胶件产品中常见的结构,也是塑胶件产品成型过程中问题比较多的结构之一 常见的螺丝柱缺陷主要有开裂.滑牙.根部断裂.产品表面缩水,发白等 ...

  • 我在米理读设计02 | 景观建筑与土地景观遗产专业:遗产不会过时,温故知新,设计未来

    Edificio 5(school of Architecture and Urban Planning) Piazza Leonardodavinci, 42 名校专业解读是LAC STUDIO推出 ...

  • 626 热敏物料低能耗干燥装置的壳管型预热器设计软件

    背景 本篇是热敏物料低能耗干燥装置系列中的一部分,其他内容可阅读与本篇封面图片相同的各篇. 基本结构 壳管型预热器基本结构如下图. 图中,料液在管内自下向上流动,含水蒸气的湿空气在管外自上向下流动:湿 ...

  • 厨房装修干货,5㎡的U型厨房设计,怎么看...

    厨房装修干货,5㎡的U型厨房设计,怎么看都不厌倦! 改造后的厨房是L型橱柜+岛台变成了便利的U型设计,这样的厨房做饭都是快乐的. [微风]关于厨房尺寸 厨房面积:1.6*3.5m: 橱柜尺寸:0.63 ...

  • 《威尼斯的小艇》探究型学习活动设计

    适用年级:五年级 所属学科:语文  教者:田恩泊 一.学习主题:<威尼斯的小艇>是马克·吐温的一篇写景散文,课文通过介绍威尼斯小艇的样子.船夫驾驶小艇的高超技术以及小艇的重要作用,为我们展 ...

  • 如何创建一个数据驱动型组织?

    本文翻译自Sara Brown发表于MIT Management Sloan School的文章. 为什么重要创建数据文化是打造数据驱动型组织的关键之一.正确的技术.数据素养和打破现状是开始的起点. ...