数组相关API
-
-
package org.sean.module02;
-
import java.util.Arrays;
-
-
public class TestArrays {
-
-
public static void iterator(int[] array) {
-
if (array != null) {
-
for (int i = 0; i < array.length; i++) {
-
System.out.print(array[i] + " ");
- }
- }
- System.out.println();
- }
-
public static void main(String[] args) {
-
-
int[] array0 = new int[10];
-
Arrays.fill(array0, 5);
- iterator(array0);
-
-
Arrays.fill(array0, 3, 8, 10);
- iterator(array0);
-
-
int[] array1 = { 7, 8, 4, 5, 1, 12, 9 };
-
System.out.print("排序前");
- iterator(array1);
- Arrays.sort(array1);
-
System.out.print("排序后");
- iterator(array1);
-
-
char[] array2 = { 'a', 'b', 'c' };
-
char[] array3 = { 'a', 'b', 'c' };
- System.out.println(Arrays.equals(array2, array3));
-
String str1 = new String(array2);
-
String str2 = new String(array3);
- System.out.println(str1.equals(str2));
-
-
System.out.println(Arrays.binarySearch(array1, 4));
-
-
int[] array4 = { 1, 2, 3, 4, 5 };
-
int[] array5 = new int[5];
-
System.arraycopy(array4, 1, array5, 0, 3);
- iterator(array5);
-
-
int[] array6 = new int[7];
- array6 = Arrays.copyOf(array4, array4.length);
- iterator(array6);
- }
- }
/**
* 测试Arrays类
*/
package org.sean.module02;
import java.util.Arrays;
/**
* @author 不落的太阳(Sean Yang)
*/
public class TestArrays {
/**
* 整型数组输出
*
* @param array
*/
public static void iterator(int[] array) {
if (array != null) {
for (int i = 0; i < array.length; i++) {
System.out.print(array[i] + " ");
}
}
System.out.println();
}
public static void main(String[] args) {
/** 填充整个数组 */
int[] array0 = new int[10];
Arrays.fill(array0, 5);
iterator(array0);
/** 填充数组的指定位置 */
Arrays.fill(array0, 3, 8, 10);
iterator(array0);
/** 数组的排序 */
int[] array1 = { 7, 8, 4, 5, 1, 12, 9 };
System.out.print("排序前");
iterator(array1);
Arrays.sort(array1);
System.out.print("排序后");
iterator(array1);
/** 数组内容的比较 */
char[] array2 = { 'a', 'b', 'c' };
char[] array3 = { 'a', 'b', 'c' };
System.out.println(Arrays.equals(array2, array3));
String str1 = new String(array2);
String str2 = new String(array3);
System.out.println(str1.equals(str2));
/**
* 使用二分法在数组中查找指定元素 如果找到返回该元素的下标,如果不存在则返回负数
*
* 使用二分法查找的数组必须经过排序
*/
System.out.println(Arrays.binarySearch(array1, 4));
/**
* 数组拷贝
*
* arraycopy(源数组, 源数组的起始位置, 目标数组, 目标数组的起始位置, 拷贝几个元素);
*/
int[] array4 = { 1, 2, 3, 4, 5 };
int[] array5 = new int[5];
System.arraycopy(array4, 1, array5, 0, 3);
iterator(array5);
/**
* JDK6.0数组拷贝
*/
int[] array6 = new int[7];
array6 = Arrays.copyOf(array4, array4.length);
iterator(array6);
}
}
约瑟夫问题使用数组解决
-
-
package org.sean.module02;
-
-
public class Count3Quit {
-
-
public static void count3Quit(boolean[] array) {
-
for (int i = 0; i < array.length; i++) {
-
array[i] = true;
- }
-
int counter = 0;
-
int leftCount = array.length;
-
int index = 0;
-
while (leftCount > 1) {
-
if (array[index] == true) {
- counter++;
-
if (counter == 3) {
-
counter = 0;
-
array[index] = false;
- leftCount--;
- }
- }
- index++;
-
if (index == array.length) {
-
index = 0;
- }
- }
-
for (int i = 0; i < array.length; i++) {
-
if (array[i] == true) {
-
System.out.println("剩余人员的位置是" + (i + 1));
- }
- }
- }
-
public static void main(String[] args) {
-
boolean[] array = new boolean[500];
- count3Quit(array);
- }
- }
/**
* 约瑟夫问题
*/
package org.sean.module02;
/**
* @author 不落的太阳(Sean Yang)
*/
public class Count3Quit {
/**
* 首先判断数组里面的元素是否为true,即人员是否在圈中,如果为true则继续计数,计数器累加
* 当计数器到达3的时候,首先计数器要归零,,然后boolean数组中该位置的元素要置为false, 同时总数减少一个,索引下标增加一个
* 由于多人首尾相连,所以当到达最后一个元素的时候,索引要归零
*
* @param array
* 要检测的数组
*/
public static void count3Quit(boolean[] array) {
for (int i = 0; i < array.length; i++) {
array[i] = true;
}
// 计数器
int counter = 0;
// 剩余人数
int leftCount = array.length;
// 索引
int index = 0;
while (leftCount > 1) {
if (array[index] == true) {
counter++;
if (counter == 3) {
counter = 0;
array[index] = false;
leftCount--;
}
}
index++;
if (index == array.length) {
index = 0;
}
}
for (int i = 0; i < array.length; i++) {
if (array[i] == true) {
System.out.println("剩余人员的位置是" + (i + 1));
}
}
}
public static void main(String[] args) {
boolean[] array = new boolean[500];
count3Quit(array);
}
}
分享到:
相关推荐
**JAVA SE学习笔记** 在Java SE(标准版)的学习中,我们主要关注的是Java编程语言的基础和核心特性,包括但不限于语法、数据类型、控制结构、类与对象、接口、异常处理、多线程、集合框架、输入/输出(I/O)系统、...
《java jdk 7学习笔记》针对java se 7新功能全面改版,无论是章节架构或范例程序代码,都做了重新编写与全面翻新。并详细介绍了jvm、jre、java se api、jdk与ide之间的对照关系。必要时从java se api的源代码分析,...
《Java JDK7学习笔记》针对java se 7新功能全面改版,无论是章节架构或范例程序代码,都做了重新编写与全面翻新。并详细介绍了jvm、jre、java se api、jdk与ide之间的对照关系。必要时从java se api的源代码分析,...
【Java SE学习笔记详解】 Java SE(Standard Edition)是Java平台的核心部分,它为开发桌面应用、服务器端应用以及中间件提供了基础。本笔记主要基于MLDN(Microsoft Learning Dynamic Network)李兴华老师的2009年...
"Java学习资料"这个压缩包显然包含了一些关于Java SE(标准版)的基础学习资源,包括笔记和实际的演示案例代码项目。Java SE是Java的核心部分,主要用于桌面应用和服务器端开发。 在Java的学习过程中,笔记通常会...
这份"java se个人学习笔记"显然是一份对Java SE基础知识的详细记录,由一位初学者整理,旨在帮助其他初学者理解这个强大的编程语言。笔记中可能涵盖了以下几个关键知识点: 1. **基础语法**:Java的基本数据类型、...
《Java JDK7学习笔记》针对java se 7新功能全面改版,无论是章节架构或范例程序代码,都做了重新编写与全面翻新。并详细介绍了jvm、jre、java se api、jdk与ide之间的对照关系。必要时从java se api的源代码分析,...
Java SE(标准版)是Java开发平台的核心部分,它提供了编写、运行和部署桌面应用程序所需的类库和工具。这份“非常详细JavaSE学习...无论你是初学者还是有经验的开发者,这份详尽的Java SE学习笔记都是一个宝贵的资源。
java SE 1.8笔记大纲 java SE 1.8是 Java 编程语言的标准版,本笔记涵盖了Java SE 1.8的所有知识点,从基本数据类型到...本笔记涵盖了 Java SE 1.8 的所有知识点,是一个非常完整和系统的 Java 编程语言学习资源。
计算机基础知识是学习计算机科学和技术的基础,它...总结来说,了解计算机基础知识对于深入学习Java SE或其他计算机编程语言是十分必要的。它不仅为我们打下坚实的理论基础,还能帮助我们更好地理解和使用计算机技术。
### 韩顺平编写的Java学习笔记概览 #### Java平台分类与运行机制 - **J2SE(Java 2 Platform, Standard Edition)**: 标准版Java开发平台,适用于桌面应用程序开发。 - **J2EE(Java 2 Platform, Enterprise ...
【JAVA SE 归档笔记】是一份由多位IT行业高手共同编撰的珍贵资料,旨在为初学者提供学习指引,并作为经验丰富的开发者们的参考手册。这份笔记深入浅出地涵盖了JAVA SE(Java Standard Edition)的核心知识点,对于...
●本书是作者多年来教学实践经验的总结,汇集了学员在学习课程或认证考试中遇到的概念、操作、应用等问题及解决方案, ●针对Java SE 8新功能全面改版,无论是章节架构或范例程序代码,都做了重新编写与全面翻新, ●...
这个压缩包中包含的"java学习笔记JDK6课件和课本代码"是学习JDK 6.0的重要参考资料,可以帮助你深入理解Java编程的核心概念和实践技巧。 1. **Java基础**:Java是一种面向对象的编程语言,它的基础包括类、对象、...
此源代码使用Java SE(标准版)环境,可能涉及到Java的基础语法、类、对象、接口、异常处理、数据类型等。 2. **Swing库**:Java Swing库是用于构建GUI应用程序的组件集合。这个项目可能使用了JFrame、JButton、...
这些基本概念构成了Java SE编程的基础,理解并掌握它们对于编写高效、可靠的Java代码至关重要。通过这些知识,开发者可以创建复杂的数据结构,实现灵活的设计模式,并构建出具有强大功能的应用程序。
1. **Java环境搭建**:首先,学习Java SE需要安装Java Development Kit (JDK),设置好环境变量`JAVA_HOME`、`PATH`和`CLASSPATH`,以便于编译和运行Java程序。 2. **Java语法基础**:Java是一种面向对象的语言,其...