在Java中,数组里面随机产生十个数(0-15),怎样判断十个数中是否有重复的数
发布网友
发布时间:2022-04-28 13:50
我来回答
共3个回答
热心网友
时间:2023-10-11 09:35
public bool CheckRepeat(int [] a) //a为求是否有重复值的数组
{
//定义一个数组测试用,思想:数组的下标和值都是上一个数组元素中的值
int [] array = new int [16] ;
//将数组的值都复制到测试数组中
for (int i = 0;i < 10;i ++)
{
int a = a [i];
array [a] = a; //或者 Array[a]=任何非零的数字,做标志用。
}
//如果数组没有重复,则会填满测试数组,否则数组中将出现自动初始化的值
int k=0; //用于计数,看array数组中为0的有多少个,如果>6个,那么就有重复值
for (int i = 1; i <16 ;i ++)
{
//判断如果数组中有自动初始的值,则数组没有被填满
if (array [i] == 0 )
{
k++;
}
}
if(k>6){
return false;
}else{
return true;
}
}
热心网友
时间:2023-10-11 09:35
把数组中的值放到set中,看set的size是否和数组的长度相同,如果相同,则没有重复的数。
set具有去重功能。
热心网友
时间:2023-10-11 09:36
循环比较:
用第1个数与后面14个数逐一相比,
用第2个数与后面13个 数 逐一比较,
……
直到最后两个数。
热心网友
时间:2023-10-11 09:35
public bool CheckRepeat(int [] a) //a为求是否有重复值的数组
{
//定义一个数组测试用,思想:数组的下标和值都是上一个数组元素中的值
int [] array = new int [16] ;
//将数组的值都复制到测试数组中
for (int i = 0;i < 10;i ++)
{
int a = a [i];
array [a] = a; //或者 Array[a]=任何非零的数字,做标志用。
}
//如果数组没有重复,则会填满测试数组,否则数组中将出现自动初始化的值
int k=0; //用于计数,看array数组中为0的有多少个,如果>6个,那么就有重复值
for (int i = 1; i <16 ;i ++)
{
//判断如果数组中有自动初始的值,则数组没有被填满
if (array [i] == 0 )
{
k++;
}
}
if(k>6){
return false;
}else{
return true;
}
}
热心网友
时间:2023-10-11 09:35
把数组中的值放到set中,看set的size是否和数组的长度相同,如果相同,则没有重复的数。
set具有去重功能。
热心网友
时间:2023-10-11 09:35
public bool CheckRepeat(int [] a) //a为求是否有重复值的数组
{
//定义一个数组测试用,思想:数组的下标和值都是上一个数组元素中的值
int [] array = new int [16] ;
//将数组的值都复制到测试数组中
for (int i = 0;i < 10;i ++)
{
int a = a [i];
array [a] = a; //或者 Array[a]=任何非零的数字,做标志用。
}
//如果数组没有重复,则会填满测试数组,否则数组中将出现自动初始化的值
int k=0; //用于计数,看array数组中为0的有多少个,如果>6个,那么就有重复值
for (int i = 1; i <16 ;i ++)
{
//判断如果数组中有自动初始的值,则数组没有被填满
if (array [i] == 0 )
{
k++;
}
}
if(k>6){
return false;
}else{
return true;
}
}
热心网友
时间:2023-10-11 09:36
循环比较:
用第1个数与后面14个数逐一相比,
用第2个数与后面13个 数 逐一比较,
……
直到最后两个数。
热心网友
时间:2023-10-11 09:35
把数组中的值放到set中,看set的size是否和数组的长度相同,如果相同,则没有重复的数。
set具有去重功能。
热心网友
时间:2023-10-11 09:36
循环比较:
用第1个数与后面14个数逐一相比,
用第2个数与后面13个 数 逐一比较,
……
直到最后两个数。