【C#】实现静态数组、动态数组
2022/1/27 14:06:39
本文主要是介绍【C#】实现静态数组、动态数组,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
任务
静态数组的实现任务
实现目标:(1)实现一个静态数组
(2)数组可以增,删,改,查;
(3)可以输出数组信息;
实现过程:
(1)创建一个新的类,包含字段元素存储,元素个数;
(2)创建构造函数,分别是一个参数的构造函数与无参数的构造函数;
(3)实现增功能,允许按照下标添加;
(4)实现查询功能,按照下标查询,按照给出元素查询;
(5)实现删除功能,按照下标删除某个元素,按照给出元素删除,删除所有元素;
(7)实现修改功能,按照下标修改,按照给出元素修改;
(8)实现输出函数;
动态数组的实现任务
实现目标:(1)对静态数组容量进行修改,使得数组可以通过实际存储的数据多少进行改变。
实现过程:(1)在原有的静态数组上新增一个自动扩容缩容的方法
重点:
(1)无参构造函数的实现方法
1 public Array1() : this(10) { } 2 //与上面无参数函数等价 3 //public Array1() 4 //{ 5 // data = new int[10]; 6 // N = 0; 7 //}View Code
(2)ToString()方法的重写
1 /// <summary> 2 /// 重写ToString方法否则不能正常输出 3 /// </summary> 4 /// <returns></returns> 5 public override string ToString() 6 { 7 //实例化 8 StringBuilder res = new StringBuilder(); 9 //重写格式1:输出数组元素个数以及长度 10 res.Append(string.Format("Array1: count={0} capacity={1}\n",N,data.Length)); 11 res.Append('['); 12 //输出元素 13 for (int i = 0; i < N; i++) 14 { 15 res.Append(data[i]); 16 if (i!=N-1) 17 { 18 res.Append(','); 19 } 20 } 21 res.Append(']'+"\n"); 22 //返回 23 return res.ToString(); 24 } 25 }View Code
(3)动态数组扩容缩容实现方法1
1 /// <summary> 2 /// 扩容缩容数组 3 /// </summary> 4 /// <param name="newcapacity"></param> 5 private void ResetCapacity(int newcapacity) 6 { 7 int[] newdata = new int[newcapacity]; 8 for (int i = 0; i < N; i++) 9 { 10 newdata[i] = data[i]; 11 } 12 data = newdata; 13 }View Code
完整代码:
1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Threading.Tasks; 6 7 namespace DataStructrue 8 { 9 class Array1 10 { 11 /// <summary> 12 /// 数组的元素存储 13 /// </summary> 14 private int[] data; 15 /// <summary> 16 /// 数组元素数量 17 /// </summary> 18 private int N; 19 20 public Array1(int capacity) 21 { 22 data = new int[capacity]; 23 N = 0; 24 } 25 public Array1() : this(10) { } 26 //与上面无参数函数等价 27 //public Array1() 28 //{ 29 // data = new int[10]; 30 // N = 0; 31 //} 32 33 /// <summary> 34 /// 在某位置添加新元素 35 /// </summary> 36 /// <param name="index"></param> 37 /// <param name="d"></param> 38 public void Add(int index,int d) 39 { 40 if (index>N || index <0) 41 { 42 throw new ArgumentException("数组索引越界"); 43 } 44 else if (N==data.Length) 45 { 46 ResetCapacity(2*N); 47 } 48 for (int i = N; i >= index; i--) 49 { 50 if (N != data.Length-1) 51 { 52 data[i + 1] = data[i]; 53 } 54 } 55 data[index] = d; 56 N++; 57 } 58 public void Addlast(int d) 59 { 60 Add(N, d); 61 } 62 /// <summary> 63 /// 删除下标元素 64 /// </summary> 65 /// <param name="index"></param> 66 public void RemoveAt(int index) 67 { 68 if (index > N || index < 0) 69 { 70 throw new ArgumentException("数组索引越界"); 71 } 72 for (int i = index; i < N; i++) 73 { 74 data[i] = data[i + 1]; 75 } 76 N--; 77 if (N==(data.Length/4)) 78 { 79 ResetCapacity(data.Length / 2); 80 } 81 data[N] = default; 82 } 83 /// <summary> 84 /// 删除特定元素 85 /// </summary> 86 /// <param name="d"></param> 87 public void Remove(int d) 88 { 89 if (Find(d)!=-1) 90 { 91 RemoveAt(Find(d)); 92 } 93 } 94 public void RemoveLast() 95 { 96 RemoveAt(N - 1); 97 } 98 /// <summary> 99 /// 清空数组 100 /// </summary> 101 public void Clear() 102 { 103 for (int i = N-1; i >=0; i--) 104 { 105 data[i] = default; 106 N--; 107 } 108 } 109 /// <summary> 110 /// 查询特定元素 111 /// </summary> 112 /// <param name="d"></param> 113 /// <returns></returns> 114 public int Find(int d) 115 { 116 for (int i = 0; i < N; i++) 117 { 118 if (data[i] == d) 119 { 120 return i; 121 } 122 } 123 return -1; 124 } 125 /// <summary> 126 /// 查询是否包含元素 127 /// </summary> 128 /// <param name="d"></param> 129 /// <returns></returns> 130 public bool Contain(int d) 131 { 132 if (Find(d)==-1) 133 { 134 return false; 135 } 136 return true; 137 } 138 /// <summary> 139 /// 修改元素 140 /// </summary> 141 /// <param name="index"></param> 142 /// <param name="d"></param> 143 public void Change(int index,int d) 144 { 145 if (index > N || index < 0) 146 { 147 throw new ArgumentException("数组索引越界"); 148 } 149 data[index] = d; 150 } 151 /// <summary> 152 /// 扩容缩容数组 153 /// </summary> 154 /// <param name="newcapacity"></param> 155 private void ResetCapacity(int newcapacity) 156 { 157 int[] newdata = new int[newcapacity]; 158 for (int i = 0; i < N; i++) 159 { 160 newdata[i] = data[i]; 161 } 162 data = newdata; 163 } 164 /// <summary> 165 /// 重写ToString方法否则不能正常输出 166 /// </summary> 167 /// <returns></returns> 168 public override string ToString() 169 { 170 //实例化 171 StringBuilder res = new StringBuilder(); 172 //重写格式1:输出数组元素个数以及长度 173 res.Append(string.Format("Array1: count={0} capacity={1}\n",N,data.Length)); 174 res.Append('['); 175 //输出元素 176 for (int i = 0; i < N; i++) 177 { 178 res.Append(data[i]); 179 if (i!=N-1) 180 { 181 res.Append(','); 182 } 183 } 184 res.Append(']'+"\n"); 185 //返回 186 return res.ToString(); 187 } 188 } 189 }View Code
这篇关于【C#】实现静态数组、动态数组的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2022-03-01沐雪多租宝商城源码从.NetCore3.1升级到.Net6的步骤
- 2024-12-06使用Microsoft.Extensions.AI在.NET中生成嵌入向量
- 2024-11-18微软研究:RAG系统的四个层次提升理解与回答能力
- 2024-11-15C#中怎么从PEM格式的证书中提取公钥?-icode9专业技术文章分享
- 2024-11-14云架构设计——如何用diagrams.net绘制专业的AWS架构图?
- 2024-05-08首个适配Visual Studio平台的国产智能编程助手CodeGeeX正式上线!C#程序员必备效率神器!
- 2024-03-30C#设计模式之十六迭代器模式(Iterator Pattern)【行为型】
- 2024-03-29c# datetime tryparse
- 2024-02-21list find index c#
- 2024-01-24convert toint32 c#