数据结构与算法之数组(1)——in dart
import 'dart:math' show Random; List<int> _array;
final _rnd = Random();
final _capacity = 100;
final _max = 100;
var _length = 0; void main() {
_array = List<int>(_capacity);
// _array = List<int>.filled(_capacity, -1); _insert();
_display(); var key = _rnd.nextInt(_max);
print('the find key is: $key');
var pos = _find(key);
if (pos < 0) {
print('can not find the key: $key.\n');
} else {
print('found the key at: $pos.\n');
} var oldValue = _modify(_length ~/ 2, _rnd.nextInt(_max));
if (oldValue != null) {
print('has modified! and oldValue is $oldValue.\n');
}
_display(); _delete(_rnd.nextInt(_max));
_display();
} void _insert() {
for (var i = 0; i < _capacity ~/ 2; i++) {
_array[i] = _rnd.nextInt(_max);
_length++;
}
} void _display() {
var sb = StringBuffer();
for (var i = 0; i < _length; i++) {
sb.write('${_array[i]}, ');
}
var s = sb.isEmpty ? '' : sb.toString().substring(0, sb.length - 2);
print('$s\n');
} int _find(int key) {
var index = -1;
for (var i = 0; i < _length; i++) {
if (_array[i] == key) {
index = i;
break;
}
}
return index;
} int _modify(int pos, int newValue) {
int oldValue;
if (pos > _length - 1) {
print('out of bound!\n');
} else {
print(
'will modify the value(${_array[pos]}) of array[$pos] to new value: $newValue');
oldValue = _array[pos];
_array[pos] = newValue;
}
return oldValue;
} void _delete(int key) {
print('the deleted key is: $key');
var pos = _find(key);
if (pos < 0) {
print('can not find the key: $key!\n');
} else {
print('the index of deleted key is: $pos\n');
for (var i = pos; i < _length - 1; i++) {
_array[i] = _array[i + 1];
}
_length--;
}
}
这是用dart语言实现的数组,因为dart内置List,且面向对象,本代码故意没有使用类和内置的List的部分特性。为了保证运行效果,采用随机数进行增删改查。
数据结构与算法之数组(1)——in dart的更多相关文章
- C语言- 基础数据结构和算法 - 动态数组
听黑马程序员教程<基础数据结构和算法 (C版本)>,照着老师所讲抄的, 视频地址https://www.bilibili.com/video/BV1vE411f7Jh?p=1 喜欢的朋友可 ...
- JavaScript 数据结构与算法1(数组与栈)
学习数据结构的 git 代码地址: https://gitee.com/zhangning187/js-data-structure-study 1.数组 几乎所有的语言都原生支持数组类型,因为数组是 ...
- Java数据结构和算法之数组与简单排序
一.数组于简单排序 数组 数组(array)是相同类型变量的集合,可以使用共同的名字引用它.数组可被定义为任何类型,可以是一维或多维.数组中的一个特别要素是通过下标来访问它.数组提供了一种将有联系的信 ...
- Java数据结构和算法总结-数组、二分查找
前言:在平时开发中数组几乎是最基本也是最常用的数据类型,相比链表.二叉树等又简单很多,所以在学习数据和算法时用数组来作为一个起点再合适不过了.本篇博文的所有代码已上传 github ,对应工程的 ar ...
- Java数据结构和算法的数组
阵列的功能: 1.固定大小 2.相同的数据类型 3. 4.数据项可反复 Java数据类型:基本类型(int和double)和对象类型.在很多编程语言中.数组也是基本类型.但在Java中把它们当作对象来 ...
- JavaScript数据结构与算法(五) 数组基础算法
- Java成神之路:第二帖---- 数据结构与算法之稀疏数组
数据结构与算法--稀疏数组 转换方法 记录数组有几行几列,有多少个不同的值 把不同的值的元素的行列,记录在一个小规模的数组中,以此来缩小数组的规模 如图: 二维数组转稀疏数组 对原始的二维数组进行遍历 ...
- 翻阅《数据结构与算法javascript描述》--数组篇
导读: 这篇文章比较长,介绍了数组常见的操作方法以及一些注意事项,最后还有几道经典的练习题(面试题). 数组的定义: JavaScript 中的数组是一种特殊的对象,用来表示偏移量的索引是该对象的属性 ...
- Java数据结构和算法(二)——数组
上篇博客我们简单介绍了数据结构和算法的概念,对此模糊很正常,后面会慢慢通过具体的实例来介绍.本篇博客我们介绍数据结构的鼻祖——数组,可以说数组几乎能表示一切的数据结构,在每一门编程语言中,数组都是重要 ...
随机推荐
- Java学习---传输安全设计
1.计算机安全的概念 用于保护数据和阻止Hacker的工具统称为计算机安全(Computer Security).信息安全最基本的方法就是利用加密信息防止未授权的人窃听,加密是以某种特殊的算法改变原有 ...
- ISA 连接非443端口的https站点提示错误
ISA 连接非443端口的https站点提示错误:12204 The specified Secure Sockets Layer (SSL) port is not allowed. ISA Ser ...
- nohup使用相关知识
常规用法nohup ./abc.sh > abc.out & --输出nohup的日志到abc.outnohup ./abc.sh & ...
- August 21st 2017 Week 34th Monday
In fact, the happiest fairy tale is no more than the simple days we have together. 其实全世界最幸福的童话,也比不上我 ...
- Java.io 包(字节流)
I/O流概述 在 Java 中,把不同类型的输入.输出源抽象为流(Stream),而其中输入或输出的数据则称为数据流(Data Stream),用统一的接口表示,从而使程序设计简单明了.流是一组有顺序 ...
- Java 封装(内部类)
1.封装 封装是指,一种将抽象性函式接口的实例细节部份包装.隐藏起来的方法.封装可以被认为是一个保护屏障,防止该类的代码和数据被外部类定义的代码随机访问.要访问该类的代码和数据,必须通过严格的接口控制 ...
- 异常处理与MiniDump详解(3) SEH(Structured Exception Handling)
write by 九天雁翎(JTianLing) -- blog.csdn.net/vagrxie 讨论新闻组及文件 一. 综述 SEH--Structured Exception Handlin ...
- 9、Node.js Stream(流)
#########################################################################介绍Node.js Stream(流)Stream 是 ...
- 017.1 stringBuffer
内容:String Buffer/String Builder方法 + 两个简单练习是缓冲区,最后都会转成字符串处理,有局限性###########方法添加元素: .append()插入元素: ...
- Odoo模块添加logo
模块的static目录是专门用于存放静态文件内容如:图片.css等的.其中,description目录是存放关于模块的一些描述性的文件的,其中,模块的图标也放在下面,以icon命名.