2020-08-25

动态数组

动态数组C++语言

vector动态数组,位于C++标准库中,所以在竞赛比较建议使用C++, 因为基本上所有C都能被C++正确编译

使用方法

C++中的vector在一个<vector>的头文件中,使用vector动态数组需要引入以下两个句子

#include<vector>
using namespace std;
初始化

方式1

//定义具有10个整型元素的向量(尖括号为元素类型名,它可以是任何合法的数据类型),不具有初值,其值不确定。
vector<int>a(10)

方式2

//定义10个整型元素,且给出的每个元素处置为1
vector<int>a(10,1);

方式3

//用向量b给向量a赋值,a的值完全等价于b的值
vector<int>a(b);

方式4

 //从数组中获得初值
int b[7]={1,2,3,4,5,6,7};
vector<int> a(b,b+7;

方式5

//将向量b中从0-2(共三个)的元素赋值给a,a的类型为int型
vector<int>a(b.begin(),b.begin+3);
插入元素

C++中通过push_back()在数组最后插入一个新元素

#include<vector>
using namespace std;
int main(){
	vector<int>vec;		//[]
	vec.push_back(1);	//[1]
	vec.push_back(2);	//[1,2]
return 0;
}inc
获取长度并且访问元素

C++中通过size()方法获取vector长度,通过[]操作直接访问

#include<vector>
#include<iosdream>
using namespace std;
int main(){
	vector<int>vec;		//[]
	vec.push_back(1);	//[1]
	vec.push_back(2);	//[1,2]
	for(int i = 0; i < vec.size(); ++i){
		printf("%d\n",vec[i]);	
	}
	return 0;
}
修改元素

直接用=赋值,比如vec[1] = 3

#include<vector>
#include<iostream>
int main(){
	vector<int>vec;		//[]
	vec.push_back(1);	//[1]
	vec.push_back(2);	//[1,2]
	vec.push_back(3);	//[1,2,3]
	vec[1] = 3;			//[1,3,3]
	vec[2] = 2;			//[1,3,2]
	return 0;
}
清空

C++中调用clear()方法就可以清空
但是使用clear()只是清空vector不会清空内存,若想清空内存,需要使用特殊方法,即先定义一个空的vector x,然后和想要清空的vector交换,因为是局部变量,所以空间会被回收

vector<int> v;
{
	vector<int> x;
	v.swap(x);
}

JAVA动态数组ArrayList

ArrayListjava.util.ArrayList包里面实现
通过import的方式引进库

import java.util.ArrayList
public class ArrayListTest{
	pubilc static void main(String[] args){
	}
}

使用方法

初始化

JAVA通过ArrayList\<T> = new ArrayList\<T>()来构造一个数据类型的ArrayList对象,T表示数据类型

插入元素
import java.util.ArrayList
public class ArrayListTest{
	pubilc static void main(String[] args){
		ArrayList<Integer>list = new ArrayList<Integer>();//[]
		list.add(1);//[1]
		list.add(2);//[1,2]
		list.add(3);//[1,2,3]
	}
}
获取长度并且访问元素

Java中通过size()获取长度,但是需要通过get(i)方法来获取第i个位子的元素

import java.util.ArrayList
public class ArrayListTest{
	pubilc static void main(String[] args){
		ArrayList<Integer>list = new ArrayList<Integer>();//[]
		list.add(1);//[1]
		list.add(2);//[1,2]
		list.add(3);//[1,2,3]
		for(int i = 0; i < list.size(); ++i){
		System.out.println(list.get(i));
		}
	}
}
修改元素

Java中若需要将index位置上的元素更改为b,需要让对象调用set(index,b)方法

import java.util.ArrayList
public class ArrayListTest{
	pubilc static void main(String[] args){
		ArrayList<Integer>list = new ArrayList<Integer>();//[]
		list.add(1);//[1]
		list.add(2);//[1,2]
		list.add(3);//[1,2,3]
		list.set(1,3);//[1,3,3]	
		list.set(2,2);//[1,3,2]
		for(int i = 0; i < list.size(); ++i){
		System.out.println(list.get(i));
		}
	}
}
清空

Java中调用clear()方法就可以清空

方法总结

C++vector方法总结

方法功能
push_back在末尾加入一个元素
pop_back从末尾弹出一个元素
size获取长度
clear清空

JavaArrayList方法总结

方法功能
add增加元素
set修改元素
get获取元素
size获取长度
clear清空
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值