`
zhongzhao_2008
  • 浏览: 36111 次
  • 性别: Icon_minigender_1
  • 来自: 合肥
最近访客 更多访客>>
社区版块
存档分类
最新评论

数组的学习2

阅读更多
Java编程那些事儿46—数组使用示例2
出自:http://blog.csdn.net/mailbomb
6.3.4 判断数组元素是否重复
要求:判断一个数组中是否存在相同的元素,如果存在相同的元素则输出“重复”,否则输出“不重复”。
该题中如果需要判断数组中元素是否重复,则需要对数组中的元素进行两两比较,如果有任意一组元素相等,则该数组中的元素存在重复,如果任意一组元素都不想等,则表示数组中的元素不重复。
实现思路:假设数组中的元素不重复,两两比较数组中的元素,使用数组中的第一个元素和后续所有元素比较,接着使用数组中的第二个元素和后续元素比较,依次类推实现两两比较,如果有一组元素相同,则数组中存储重复,结束循环。把比较的结果存储在一个标志变量里,最后判断标志变量的值即可。
则实现的代码如下:
int[] n = {1,2,3,1,0};
boolean flag = true; //假设不重复
for(int i = 0; i < n.length – 1; i++){ //循环开始元素
for(int j = i + 1; j < n.length; j++){ //循环后续所有元素
//如果相等,则重复
if(n[i] == n[j]){
flag = false; //设置标志变量为重复
break; //结束循环
}
}
}
//判断标志变量
if(flag){
System.out.println(“不重复”);
}else{
System.out.println(“重复”);
}
在该代码中,flag变量存储是否重复,true代表不重复,false代表重复。外部循环中循环变量i代表第一个元素的下标,内部循环中循环变量j代表后续元素的下标,当i为零时和后续所有元素比较,然后当i为1时也和后续所有元素比较,依次类推,这样实现所有元素之间的两两比较。然后如果元素相同,则代表有重复,把flag变量的值置成flase,结束循环。最后根据flag变量的值就可以判断是否重复了。
6.3.5 判断数组是否对称
要求:判断数组元素是否对称。例如{1}、{1,2,0,2,1},{1,2,3,3,2,1}这样的都是对称数组。
该题中用于判断数组中的元素关于中心对称,也就是说数组中的第一个元素和最后一个元素相同,数组中的第二个元素和倒数第二个元素相同,依次类推,如果比较到中间,所有的元素都相同,则数组对称。
实现思路:把数组长度的一半作为循环的次数,假设变量i从0循环到数组的中心,则对应元素的下标就是数组长度-i-1,如果对应的元素有一组不相等则数组不对称,如果所有对应元素都相同,则对称。
则实现的代码如下:
int[] n = {1,2,0,2,1};
boolean flag = true; //假设对称
for(int i = 0; i < n.length/2; i++){ //循环数组长度的一半次
//比较元素
if(n[i] != n[n.length – i – 1]){
flag = false; //不对称
break; //结束循环
}
}
if(flag){
System.out.println(“对称”);
}else{
System.out.println(“不对称”);
}
在该代码中,flag作为标志变量,值为true代表对称,false代表不对称,因为是两两比较,只需要比较数组的长度一半次即可,如果对应的元素不相同则数组不对称,结束循环。最后判断标志变量的值,就可以获得数组是否对称了。
6.3.6 数制转换
要求:将十进制数字转换为二进制数字。
在前面介绍过,十进制数字转换为二进制数字时一般使用除二取余法,该方法很规则,在程序中可以通过循环实现,在程序中只需要把得到的数字存储起来即可。
实现思路:将除二取余得到的第一个数字存储在数组中第一个元素,第二次得到的余数存储在数组中第二个元素,依次类推,最后反向输出获得的数字即可。
实现代码如下:
int n = 35;
int[] m = new int[32];
//拆分数字
int num = 0;
while(n != 0){
m[num] = n % 2; //存储余数
num++; //拆分数字增加1
n /= 2; //去掉余数
}
//输出拆分后的数字
for(int i = num - 1; i >= 0; i--){
System.out.print(m[i]);
}
System.out.println();
在该代码中,因为int是32位的,所以最多需要长度是32的数组即可。在存储时把拆分出的第一个数字,也就是二进制的低位,存储在数组的第一个元素,num代表拆分出的数字的个数以及数组下标,一直拆分到n的值为零时结束。循环结束后,因为拆分出来的数字个数是num,所以只需要反向输出数组中0到num-1下标的元素即可。
分享到:
评论

相关推荐

    数组学习心得

    2) 数组对象动态初始化 ary = new int[4]; //数组变量引用了具体数组对象, 就是代词 指代了具体事务. 数组元素是自动初始化的, 自动初始化为"零"值. "零"值: 0, 0.0, \u0000, false, null ary = new int[]{1,2...

    C语言数组学习教案.pptx

    "C语言数组学习教案" 本节课件主要讲解C语言中的数组知识点,包括数组的定义、引用、初始化等基本概念和操作。 一、数组的定义 在C语言中,数组是一种构造数据类型,由基本数据类型通过一定的规则组合而成。定义...

    asp.net c# 数组学习

    一维数组类似于线性列表,多维数组则可以理解为表格形式的数据,而交错数组是由多个数组组成的数组,每个子数组可以有不同的大小。 声明不同类型的数组示例如下: - 一维数组:`int[] numbers` - 多维数组:`...

    VB数组学习教案.pptx

    VB数组学习教案.pptx

    php数组学习之一

    本篇文章将聚焦于“php数组学习之一”,深入探讨PHP数组的基础概念、类型、创建方式以及一些常用的数组操作函数。 首先,PHP中的数组分为索引数组和关联数组两种类型。索引数组是由数字索引(默认从0开始)组成的...

    VBA数组学习笔记.pdf

    VBA 数组学习笔记 VBA 数组学习笔记是指在 Visual Basic for Applications(VBA)中对数组的学习和应用。数组是 VBA 编程中非常重要的一部分,它可以用来存储和处理大量的数据。 数组的声明 在 VBA 中,数组的...

    C++数组的学习笔记(入门).docx

    C++数组的学习笔记(入门) C++数组是一种重要的数据结构,数组是相同类型元素的集合。在C++中,数组可以分为一维数组、二维数组和字符数组等。本文将对C++数组的定义、初始化和引用进行详细的介绍。 一维数组 一...

    c++数组学习资料

    c++数组学习资料

    数组参数学习内容

    本学习内容主要聚焦于“数组参数”,让我们深入探讨这个主题。 数组参数允许我们将整个数组作为单一参数传递给函数。这在处理大量数据时非常有用,因为它减少了函数调用的次数,提高了程序效率。在大多数编程语言中...

    易语言动画框数组学习

    本主题聚焦于“易语言动画框数组学习”,这是一段用于理解与操作动画框数组的源代码。 动画框在易语言中是一个重要的图形用户界面(GUI)元素,它可以显示动态图像或动画效果,通常用于增强程序的视觉表现力。动画...

    C语言教学之数组学习教案.pptx

    C语言教学之数组学习教案.pptx

    PHP之数组学习

    今天学习了数组,可以说是PHP的数据应用中较重要的一种方式。PHP的数组函数众多,下面是我学习的小结,借此记之,便于以后鉴之…… 一、数组定义: 数组的定义使用 array()方式定义,可以定义空数组: 复制代码 ...

    C语言二维数组学习教案.pptx

    C语言二维数组学习教案.pptx

    动画框数组学习.rar

    本资源“动画框数组学习.rar”显然是一个压缩包,包含了一个易语言(EasyLanguage)的源代码示例,用于教授如何使用动画框数组进行编程。易语言是一款面向初学者的中文编程软件,它的语法简洁明了,适合初学者学习...

    动态数组 学习C++的经典例子

    这个“动态数组学习C++的经典例子”很可能是包含了一些演示如何使用C++管理动态数组的代码示例。 动态数组主要通过C++中的指针和内存管理函数来实现。在C++中,我们通常使用`new`操作符来动态分配内存,创建一个可...

    JAVA数组学习教程

    【JAVA数组学习教程】 在Java编程中,数组是一种基础且重要的数据结构,它允许程序员存储一组具有相同类型的元素。数组的使用是程序设计中的常见环节,尤其对于初学者来说,理解数组的概念和操作至关重要。 首先,...

    VBA数组的学习笔记,让你更好的了解数组

    ### VBA数组学习笔记 #### 一、数组的声明与初始化 在VBA中,数组是一种非常重要的数据结构,用于存储一系列同类型的值。数组的声明与其他变量类似,可以通过`Dim`、`Static`、`Private`或`Public`语句进行。与...

    c语言数组学习

    c语言数组学习

    一维数组习题,检测数组学习效果

    一维数组习题,检测数组学习效果

Global site tag (gtag.js) - Google Analytics