1. 정수 배열의 순차 축소
public static int seqSearch(int[] arr, int first, int last, int target) { for (int i = first; i <p>1.1 위의 방법을 추상화하면 ***Java의 Object 참조를 사용하여 일반적인 방법을 구현한다고 생각해보자</p><pre class="brush:php;toolbar:false">public static int seqSearch(Object[] arr, int first, int last, Object target) { for (int i = first; i <p>2.1 Object 참조와 비슷해 매우 편리하고, 두 번째 순차 검색에서는 float, double, String 등을 사용할 수 있습니다. 더 공부하면 문제가 발생합니다 </p><pre class="brush:php;toolbar:false">public static void selectionSort(int[] arr) { int n = arr.length, smallIndex = 0; for (int i = 0; i arr[j]) // 选择最小的索引j smallIndex = j; // if (smallIndex != i) { exchange(arr, i, smallIndex);// 交换array[i]与 min(array[i+1,..,n]) // } } }
2.2 위 코드는 순차 정렬 알고리즘입니다. 일반적인 메소드를 작성하려면 Comparable 인터페이스를 구현하는 메소드에 객체 유형을 강제해야 합니다.
JVM은 유형 강제 변환을 처리할 때 경고를 표시합니다. Cast를 선택 해제하세요
@SuppressWarnings("unchecked") public static void selectionSort(Object[] arr) { int n = arr.length, smallIndex = 0; for (int i = 0; i )arr[smallIndex]).compareTo(((Comparable<object>)arr[j])) > 0) // 选择最小的索引j smallIndex = j; // if (smallIndex != i) { exchange(arr, i, smallIndex);// 交换array[i]与 min(array[i+1,..,n]) // } } }</object>
실제 매개변수를 사용할 때 Comparable 인터페이스가 구현되지 않으면 컴파일러가 일반적인 문제를 처리하기 위해 객체 참조를 사용한다는 것을 알 수 있습니다. will CastClassException 런타임 예외를 발생시킵니다. 그러한 프로그램은 안전하지 않습니다.
3.1 객체 참조를 사용하여 알고리즘(예: 순차 검색)을 일반화합니다. 객체 참조와 배열의 대상 값을 사용하여 데이터 유형이 equals 메소드를 구현하는 한 알고리즘에서 비교할 데이터 클래스는 Comparable 인터페이스를 구현해야 합니다. 이제 이 문제를 해결하기 위해 Java 제네릭을 사용하겠습니다.
public static <t>> void selectionSort(T[] arr){ int n = arr.length; int smallIndex; for (int i = 0; i Arrays 클래스의 정적 메소드 SelectionSort()에서 이 메소드는 정수 유형을 처리합니다. 이 알고리즘을 구현하기 위해 제네릭 버전을 사용하려면 제네릭 유형 배열 T[]의 두 요소를 비교해야 하므로 실제 매개변수를 전달하는 객체 유형이나 해당 슈퍼클래스는 Comparable 인터페이스를 구현해야 합니다. <p></p></t>
위 내용은 제네릭을 사용하여 Java에서 배열 정렬을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于结构化数据处理开源库SPL的相关问题,下面就一起来看一下java下理想的结构化数据处理类库,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于PriorityQueue优先级队列的相关知识,Java集合框架中提供了PriorityQueue和PriorityBlockingQueue两种类型的优先级队列,PriorityQueue是线程不安全的,PriorityBlockingQueue是线程安全的,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于java锁的相关问题,包括了独占锁、悲观锁、乐观锁、共享锁等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于多线程的相关问题,包括了线程安装、线程加锁与线程不安全的原因、线程安全的标准类等等内容,希望对大家有帮助。

本篇文章给大家带来了关于Java的相关知识,其中主要介绍了关于关键字中this和super的相关问题,以及他们的一些区别,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于枚举的相关问题,包括了枚举的基本操作、集合类对枚举的支持等等内容,下面一起来看一下,希望对大家有帮助。

封装是一种信息隐藏技术,是指一种将抽象性函式接口的实现细节部分包装、隐藏起来的方法;封装可以被认为是一个保护屏障,防止指定类的代码和数据被外部类定义的代码随机访问。封装可以通过关键字private,protected和public实现。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于设计模式的相关问题,主要将装饰器模式的相关内容,指在不改变现有对象结构的情况下,动态地给该对象增加一些职责的模式,希望对大家有帮助。


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구
