向量的(查、增、删、改)

  1 #include "stdafx.h"
  2 #include <iostream>
  3 using namespace std;
  4 template <typename T>
  5 #define DEFAULT_CAPACITY 3
  6 class vector
  7 {
  8 private:
  9     int size;
 10     int capacity;
 11     T* elem;                    //定义数据区
 12 public:
 13     vector();                    //构造函数
 14     void insert(T &e, int i);
 15     void expand();                //扩容
 16     void shrink();                //缩容
 17     T remove(int i);            //删除
 18     void print();
 19     T &operator[] (int r);      //重载下标操作符,类似于数组形式引用各元素
 20     int getsize();              //获取当前元素总数
 21 };
 22
 23 template <typename T>
 24 vector<T>::vector()
 25 {
 26     capacity = DEFAUL_CAPACITY 3
 27         elem = new T[capacity];
 28     size = 0;
 29 }
 30
 31 template <typename T>
 32 void Vector<T>::insert(T &e, int i)
 33 {
 34     int j;
 35     expand();     //若有必要,扩容
 36     for (j = size; j>i; j++)
 37     {
 38         elem[j] = elem[j - 1];
 39     }
 40     elem[i] = e;
 41     size++;
 42 }
 43
 44 template <typename T>
 45 void Vector<T>::expand()
 46 {
 47     if (size < capacity)
 48         return;
 49     cout << "expand" << endl;
 50     T *oldElem = elem;
 51     elem = new T[capacity <<= 1];
 52     for (int i = 0; i<size; i++)
 53         elem[i] = oldElem[i];
 54     delete[] oldElem;
 55 }
 56 template <typename T>
 57 T Vector<T>::remove(int i)
 58 {
 59     int j;
 60     T e;
 61     e = elem[i];
 62     for (j = i + 1; j<size; j++)
 63     {
 64         elem[j - 1] = elem[j];
 65     }
 66     size--;
 67     shrink();
 68     return e;
 69 }
 70 template <typename T>
 71 void Vector<T>::shrink()
 72 {
 73     if (capacity < DEFAULT_CAPACITY)
 74         return;
 75     if ((size * 4) <= capacity)
 76     {
 77         cout << "shrink" << endl;
 78         T *oldElem = elem;
 79         elem = new T[capacity >>= 1];
 80         for (int i = 0; i<size; i++)
 81             elem[i] = oldElem[i];
 82         delete[] oldElem;
 83     }
 84 }
 85
 86 template <typename T>
 87 void Vector<T>::print()
 88 {
 89     int i;
 90     for (i = 0; i<size; i++)
 91         cout << elem[i] << endl;
 92     cout << endl;
 93 }
 94
 95 template <typename T>
 96 T & Vector<T>::operator[](int r)
 97 {
 98     return elem[r];
 99 }
100
101 template <typename T>
102
103 int Vector<T>::getsize()
104 {
105     return size;
106 }
时间: 2024-08-19 09:04:16

向量的(查、增、删、改)的相关文章

ADO.NET 增 删 改 查

ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访问技术的基础 连接数据库基本格式:需要两个类1.数据库连接类 SqlConnection2.数据库操作类 SqlCommand 1.连接数据库写连接字符串,立马就要想到有4点要写完,1.连接哪台服务器,2.连接哪个数据库,3.连接用户名,4.密码string sql = "server=.(服务器i

Python---MySQL数据库之四大操作(增 删 改 查)

一.对数据库,表,记录---四大操作(增 删 改 查) 1.操作数据库 (1)对数据库(文件夹):进行增加操作 Create  database  库名; 例:  Create  database  db7 ; 查询库: show  databases; 结果: +-----------------------------+ | Database                   | +----------------------------+ | information_schema | |

第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据

第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据 ADO.NET 为什么要学习? 我们要搭建一个平台(Web/Winform)让用户方便的操作数据库中的数据. 什么是ADO.NET 是一组库类,System.Data. Ado.net组成 Connection:用来连接数据库 Command:用来执行SQL语句 DataReader:只读.只进的结果集,一条一条读取数据(SteamReader.XmlReader) Da

oracle 11g 建库 建表 增 删 改 查 约束

一.建库 1.(点击左上角带绿色+号的按钮) 2.(进入这个界面,passowrd为密码.填写完后点击下面一排的Test按钮进行测试,无异常就点击Connect) 二.建表 1-1. create table 表名1( Tid number(4) --primary key 列级约束(主键), Tname varchar(10) --ont null  非空约束,只能定义在列级约束, Tsex varchar2(2)--check (tsex='男'  or  tsex='女') 检查约束, T

数据库基础学习4--表格的 增 删 改 查(简单查询与高级查询)

一.增 C:create 增加,创建,向数据库里面添加数据. insert into Fruit values('K009','苹果',3.0,'高青',90,'') insert into Fruit(Ids,Name,Price,Source,Numbers) values('K010','苹果',3.0,'高青',90) 二.改 U:update修改,从数据库表里面修改数据. update Fruit set Source='烟台' where Ids='K001' 三.删 D:delet

SQL 增/删/改/查 (总结)

1.增 INSERT  INTO  表名  VALUES (" "," ") ; INSERT INTO 表名(字段)  VALUES(" "); 2. 删 DELETE   FROM 表名  WHERE  ... 3.改 UPDATE  表名 SET   ... WHERE  ... 4.查 SELECT × FROM  表名 ORDER BY ...

1-24.list的增,删,改,查

增: 1.append(通过元素增加,默认加在最后print(a.append('hgf'))) 2.extend( 迭代的去增,就是把字符串的字符逐个去给这个列表加上去) 3.insert((按照索引去增加,前为索引,后为增加的字) 删: 1,pop(通过位置索引去删除) 2.del (通过索引,切片删除) 3.clear(清空列表) 4.remove(通过元素去删除) #返回值是什么意思? 改: a[]='i' print() 查: for i in a: print(a) 其他列表 1.s

php基础:数据库的含义和基本操作 增 删 改 查

//数据库是帮我们管理数据的一个软件,我们将数据给他,放进数据库里.他能很稳妥的帮我们管理起来,且效率很高.//php的大部分工作就是  php->连接数据库->写入数据->查出数据->格式化数据->显示出来,//数据库管理数据是以表的形式组成的,多行多列,表头声明好了,一个表创建好了,剩下的就是往里面添加数据 多张表放在一个文件夹里面就形成了库  mysql服务器帮我们管理多个库C:\wamp\bin\mysql\mysql5.6.12\data   数据库中的数据放在这个

Android 增,删,改,查 通讯录中的联系人

一.权限 操作通讯录必须在AndroidManifest.xml中先添加2个权限, <uses-permission android:name="android.permission.READ_CONTACTS"></uses-permission> <uses-permission android:name="android.permission.WRITE_CONTACTS"></uses-permission>

js数组的管理[增,删,改,查]

今天在设计表单的时候遇到对数组的一些处理的问题,比如说怎么创建一个数组,然后牵扯到数组的增删改查的方法.请看API FF: Firefox, N: Netscape, IE: Internet Explorer 方法 描述 FF N IE concat() 连接两个或更多的数组,并返回结果. 1 4 4 join() 把数组的所有元素放入一个字符串.元素通过指定的分隔符进行分隔. 1 3 4 pop() 删除并返回数组的最后一个元素 1 4 5.5 push() 向数组的末尾添加一个或更多元素,