Java算法分析1—————寻找数组同样元素
算法的两个评測指标:执行时间和内存消耗
要么用时间换空间,要么用空间换时间
寻找数组同样元素測试一:
0~99共100个元素各不同样,新增加一个0~99的元素不明白位置
从101个元素数组中找出与0~99元素中反复的一个
/* 找同样元素
* 0~99共100个元素各不同样
* 从101个元素数组中找出与0~99元素中反复的一个
*/
public class Dome01 {
public static void main(String[] args) {
int arr[] = new int[101];
for (int i = 0; i < 100; i++) {
arr[i] = i;
}
arr[100] = 38; // 假定反复元素为38
// 将数组元素打乱 Math.random() 取值范围是[0,1) // 怎样打乱数据? ? for (int j = 0; j < 1000; j++) { // 进行1000次数据打乱的操作
int num1 = (int) (Math.random() * 101); // num取值范围是[0,101)
int num2 = (int) (Math.random() * 101);
int temp = arr[num1];
arr[num1] = arr[num2];
arr[num2] = temp;
} // 算法一:用双循环实现
Jonney: for (int i = 0; i < arr.length; i++) {
// 将数组元素依次与后面的数组元素比較
for (int j = i + 1; j < arr.length; j++) {
if (arr[i] == arr[j]) {
System.out.println("反复元素是:" + arr[i]);
break Jonney; // 退出双循环
}
}
}
// 算法一效率太低 // 算法二:将数组的元素所有累加起来就是0~99的数据+同样元素 再减去0~99的和
int sum = 0;
for (int i = 0; i < arr.length; i++) {
sum += arr[i];
}
for (int j = 0; j < 100; j++) {
sum -= j;
}
System.out.println("反复元素是:" + sum);
// 算法二假设计算的数据太多就会有数据溢出 // 算法三:使用异或解决
// 0^1^2^3^4^...^m...^99^m^0^1^2^3^4^...^m...^99=m
// 使用数组的第一个元素异或后面的所有元素
for (int i = 1; i < arr.length; i++) {
arr[0] = arr[0] ^ arr[i];
}
// 再次将arr[0]保存的结果与0~99异或一次
for (int i = 0; i < 100; i++) {
arr[0] = arr[0] ^ i;
}
System.out.println("反复元素是:" + arr[0]);
// 算法三才是最佳算法
}
}
寻找数组同样元素測试二:
0~99共100个整数,各不同样,将全部数放入一个数组,随机排布
数组长度100,将当中随意一个数替换成0~99还有一个数(唯一反复的数字)
将反复的数字找出
/*
* 0~99共100个整数,各不同样,将全部数放入一个数组,随机排布
* 数组长度100,将当中随意一个数替换成0~99还有一个数(唯一反复的数字)
* 将反复的数字找出
*/
public class Dome2 { public static void main(String[] args) {
int arr[] = new int[100];
for (int i = 0; i < arr.length; i++) {
arr[i] = i;
}
// 随机排布
for (int i = 0; i < 1000; i++) {
int num1 = (int) (Math.random() * 100);
int num2 = (int) (Math.random() * 100);
int temp = arr[num1];
arr[num1] = arr[num2];
arr[num2] = temp;
}
// 用某个值给某个值替换
int num1 = (int) (Math.random() * 100);
int num2 = (int) (Math.random() * 100);
// 保证num1与num2不同
while (num1 == num2) {
num1 = (int) (Math.random() * 100);
}
System.out.println("将" + num1 + "位置的值用" + num2 + "的位置替换");
arr[num1] = arr[num2];
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + "\t");
} // 算法实现:
// 算法一:用双循环实现
Jonney: for (int i = 0; i < arr.length; i++) {
// 将数组元素依次与后面的数组元素比較
for (int j = i + 1; j < arr.length; j++) {
if (arr[i] == arr[j]) {
System.out.println("反复元素是:" + arr[i]);
break Jonney; // 退出双循环
}
}
}
// 算法一效率太低 // 算法二:用数组优化的算法
// 定义一个新数组 int newArr[]=new int[100] 默认值为0
// 把原始数组的元素作为新数组的下标,假设该下标相应的新数组元素存在,就将该元素值+1=1
/*
* 原始数组 8 3 7 2 1 5 6 8 0
* 新数组 0 0 0 0 0 0 0 0 0
* 对新数组+1 1 1 1 1 0 1 1 1 2
*/
// 新数组中元素为2的值的下标就是反复元素
int newArr[] = new int[100];
for (int i = 0; i < arr.length; i++) {
newArr[arr[i]]++; // 将原始元素对于新数组的索引下标
if (newArr[arr[i]] == 2) {
System.out.println("反复元素是:" + arr[i]);
}
} } }
PS:測试二中的新定义个新数组的数组优化算法,尽管加快了查询速度。但也加大了内存开销
Java算法分析1—————寻找数组同样元素的更多相关文章
- Leetcode724:寻找数组的中心索引(java、python3)
寻找数组的中心索引 给定一个整数类型的数组 nums,请编写一个能够返回数组"中心索引"的方法. 我们是这样定义数组中心索引的:数组中心索引的左侧所有元素相加的和等于右侧所有元素相 ...
- Java实现 蓝桥杯 算法训练 寻找数组中最大值
算法训练 寻找数组中最大值 时间限制:1.0s 内存限制:512.0MB 提交此题 问题描述 对于给定整数数组a[],寻找其中最大值,并返回下标. 输入格式 整数数组a[],数组元素个数小于1等于10 ...
- 寻找数组中的第K大的元素,多种解法以及分析
遇到了一个很简单而有意思的问题,可以看出不同的算法策略对这个问题求解的优化过程.问题:寻找数组中的第K大的元素. 最简单的想法是直接进行排序,算法复杂度是O(N*logN).这么做很明显比较低效率,因 ...
- java数组集合元素的查找
java数组和集合的元素查找类似,下面以集合为例. 数组集合元素查找分为两类: 基本查找: 二分折半查找: 基本查找: 两种方式都是for循环来判断,一种通过索引值来判断,一种通过数组索引判断. 索引 ...
- java去除数组重复元素的方法
转载自:https://blog.csdn.net/Solar24/article/details/78672500 import java.util.ArrayList; import java.u ...
- 【算法31】寻找数组的主元素(Majority Element)
题外话 最近有些网友来信问我博客怎么不更新了,是不是不刷题了,真是惭愧啊,题还是在刷的,不过刷题的频率没以前高了,看完<算法导论>后感觉网上很多讨论的题目其实在导论中都已经有非常好的算法以 ...
- Java比较两个数组中的元素是否相同的最简单方法
import java.util.Arrays; public class Test { /** * Java比较两个数组中的元素是否相同 */ public static void main(Str ...
- Java实现 LeetCode 724 寻找数组的中心索引(暴力)
724. 寻找数组的中心索引 给定一个整数类型的数组 nums,请编写一个能够返回数组"中心索引"的方法. 我们是这样定义数组中心索引的:数组中心索引的左侧所有元素相加的和等于右侧 ...
- Java实现找出数组中重复次数最多的元素以及个数
/**数组中元素重复最多的数 * @param array * @author shaobn * @param array */ public static void getMethod_4(int[ ...
随机推荐
- [置顶] 手把手教你iOS消息推送证书生成以及Push消息
iOS推送消息是许多iOS应用都具备的功能,今天在给应用加推送功能,在生成证书的过程中,发生了各种令人蛋痛的事.下面就把步骤拿出来分享下: iOS消息推送的工作机制可以简单的用下图来概括: Provi ...
- ie 64bit调用activex控件
1,首先,这是可能的.不要被网上一堆ie64调不了activex控件的文章误导了.flash就是一个现成的例子,flash支持ie64. 2,ie64只能调用64bit的activex控件.网上那些说 ...
- 【从零学习openCV】opecv操作像素
1. 存取像素值 在opencv中能够直接对cv::Mat类型的图像调用at函数读取或赋值某个像素,我们用个简单的案例来说明: //在一张图像上增加椒盐噪声,image为输入图像.n为噪点个数 voi ...
- java中subString、split、stringTokenizer三种截取字符串方法的性能比较(转)
最近在阅读java.lang下的源码,读到String时,突然想起面试的时候曾经被人问过:都知道在大数据量情况下,使用String的split截取字符串效率很低,有想过用其他的方法替代吗?用什么替代? ...
- address_space 从哪里来
address_space 从哪里来 这两天想弄清楚linux的内存分配,忽然看到了address_space,就想弄明白. 整个内核就见到 address_space(1)和address_spac ...
- WAS ND集群中的HTTP内存会话复制对Java应用程序序列化编程的要求
应用程序需要遵守的约定 在会话中没有自定义对象时,WAS 集群的 HTTP 会话内存复制特性成功地实现了高可用性,使用户在宕机过程中的会话信息没有丢失,操作没有受到任何影响. 在会话中包含自定义对象时 ...
- [51daifan]来吧,一起书写51daifan的成长史吧-让一部分人先安全起来
对新创项目而言,是idea更重要,还是执行力更重要?在没有用户时,我们该如何冷启动?团队.人.技术.产品.推广和拜春哥,哪一个更重要?到底是什么决定了一个项目的生存或者毁灭? 来吧,一起书写51dai ...
- HOJ 2245 浮游三角胞(数学啊 )
题目链接:http://acm.hrbust.edu.cn/index.php?m=ProblemSet&a=showProblem&problem_id=2245 Time Limi ...
- web.xml中listener作用及使用
一.WebContextLoaderListener 监听类 它能捕捉到server的启动和停止,在启动和停止触发里面的方法做对应的操作! 它必须在web.xml 中配置才干使用,是配置监听类的 二. ...
- 调试Release发布版程序的Crash错误
http://www.cppblog.com/Walker/archive/2012/11/08/146153.html http://blog.sina.com.cn/s/blog_48f93b53 ...