目录
- 数组的扩容
- 往数组指定位置插入数据
- 时间复杂度
学习内容
一、数组的扩容
当插入数据超出数组的可容纳数据的最大量时,建立一个新数组(新数组的长度与旧数组长度有关联)
遍历旧数组,将旧数组的每个值赋给新数组,再将新数组给旧数组。
1 int[] arr=new int []{1,2,3,4}; 2 int[] newArr=new int[arr.length+2]; 3 for (int i = 0; i <arr.length ; i++) { 4 newArr[i]=arr[i]; 5 } 6 arr=newArr;
二、往数组指定位置插入数据
1、将指定下标的数据存在一个临时变量里,将要插入的数据存入该下标
2、对数组进行扩容
3、将数组第i-1个数据赋值给i(i=数组长度-n,n=1~数组长度-指定下标)
4、将临时变量赋值指定下标+1里;
1 int[] arr=new int[]{1,2,3}; 2 int[] newArray=new int[arr.length*2]; 3 for (int i = 0; i < arr.length; i++) { 4 newArray[i]=arr[i]; 5 } 6 arr=newArray; 7 Scanner sc =new Scanner(System.in); 8 System.out.println("请选择要插入数据的下标:"); 9 int index=sc.nextInt(); 10 System.out.println("请输入要插入的数据:"); 11 int num=sc.nextInt(); 12 int temp=arr[index]; 13 arr[index]=num; 14 for (int i =1; i < arr.length-index; i++) { 15 arr[arr.length-i]=arr[arr.length-i-1]; 16 } 17 arr[index+1]=temp; 18 System.out.println(Arrays.toString(arr));
三、时间复杂度
时间复杂度:算法的时间复杂度,是一个用于度量一个算法的运算时间的一个描述,本质是一个函数,根据这个函数能在不用具体的测试数据来测试的情况下,粗略地估计算法的执行效率,换句话讲时间复杂度表示的只是代码执行时间随数据规模增长的变化趋势。
时间复杂度O(1)最小,递归/阶乘阶最大。
时间复杂度越小,算法运行效率越高。
学习心得
今天是复习课,感觉良好。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧