二分查找:

public class Q212 {
public static void main(String [] args) {
Integer []arr = {1,2,3,4,5,6,7,8};//Integer型比较
System.out.println(Q212.<Integer>Erfen(arr, 5)); String []arr1 = {"a","b","c","d","e","f","g"};//String型比较
System.out.println(Q212.<String>Erfen(arr1, "d")); Double []arr2 = {3.1,4.3,5.4,6.5,7.3,8.1,9.2,10.7};//Double型比较
System.out.println(Q212.<Double>Erfen(arr2, 9.2));
} public static <E extends Comparable<E>> int Erfen(E []list,E index) {
int first = 0;
int last = list.length - 1;
int mid; while(first<=last) {
mid = first + (last - first)/2;
if(list[mid].compareTo(index) == 0)
return mid;
if(list[mid].compareTo(index) < 0)
first = mid + 1;
if(list[mid].compareTo(index) > 0)
last = mid - 1;
}
return -1;
}
}

选择排序:

public class Q213 {
public static void main(String []args) {
Integer []arr = {5,4,1,6,2};
Q213.<Integer>selectionSort(arr);
for(int i = 0;i < arr.length; i++)
System.out.print(arr[i]+" ");
} public static <E extends Comparable<E>> void selectionSort(E []list) {
int i,j;
for(i = 0;i < list.length-1; i++/*,System.out.println("nihao")*/)
for(j = i+1;j < list.length; j++)
if(list[j].compareTo(list[i]) < 0)
//swap(list[i],list[j]);
{
//System.out.println(list[i]+" "+list[j]);
E m = list[i];
list[i] = list[j];
list[j] = m;
}
//for(i = 0;i < list.length; i++)
//System.out.print(list[i]+" ");
}
/*
public static <E>void swap(E x,E y) {
E m;
m = x;
x = y;
y = m;
}*/ }

插入排序:

public class Q214 {
public static void main(String []args) {
Integer []arr = {2,3,6,1,8,3};
Q214.<Integer>insertionSort(arr); for(int i=0;i<arr.length;i++) {
System.out.print(arr[i]+" ");
}
} public static <E extends Comparable<E>> void insertionSort(E []list) {
int i,j;
for(i = 1;i<list.length;i++)
for(j=0;j<i;j++)
if(list[i].compareTo(list[j])<0) {
E m = list[i];
for(int p = i-1; p>=0; p--)
list[i--] = list[p];
list[i] = m;
}
}
}

JAVA 泛型练习的更多相关文章

  1. Java泛型的历史

    为什么Java泛型会有当前的缺陷? 之前的章节里已经说明了Java泛型擦除会导致的问题,C++和C#的泛型都是在运行时存在的,难道Java天然不支持“真正的泛型”吗? 事实上,在Java1.5在200 ...

  2. 浅析Java 泛型

    泛型是JavaSE5引入的一个新概念,但是这个概念在编程语言中却是很普遍的一个概念.下面,根据以下内容,我们总结下在Java中使用泛型. 泛型使用的意义 什么是泛型 泛型类 泛型方法 泛型接口 泛型擦 ...

  3. Java:泛型基础

    泛型 引入泛型 传统编写的限制: 在Java中一般的类和方法,只能使用具体的类型,要么是基本数据类型,要么是自定义类型.如果要编写可以应用于多种类型的代码,这种刻板的限制就会束缚很多! 解决这种限制的 ...

  4. java泛型基础

    泛型是Java SE 1.5的新特性, 泛型的本质是参数化类型, 也就是说所操作的数据类型被指定为一个参数. 这种参数类型可以用在类.接口和方法的创建中, 分别称为泛型类.泛型接口.泛型方法.  Ja ...

  5. 使用java泛型设计通用方法

    泛型是Java SE 1.5的新特性, 泛型的本质是参数化类型, 也就是说所操作的数据类型被指定为一个参数. 因此我们可以利用泛型和反射来设计一些通用方法. 现在有2张表, 一张user表和一张stu ...

  6. 关于Java泛型的使用

    在目前我遇到的java项目中,泛型应用的最多的就属集合了.当要从数据库取出多个对象或者说是多条记录时,往往都要使用集合,那么为什么这么使用,或者使用时有什么要注意的地方,请关注以下内容. 感谢Wind ...

  7. 初识java泛型

    1 协变数组类型(covariant array type) 数组的协变性: if A IS-A B then A[] IS-A B[] 也就是说,java中的数组兼容,一个类型的数组兼容他的子类类型 ...

  8. 【Java心得总结四】Java泛型下——万恶的擦除

    一.万恶的擦除 我在自己总结的[Java心得总结三]Java泛型上——初识泛型这篇博文中提到了Java中对泛型擦除的问题,考虑下面代码: import java.util.*; public clas ...

  9. 【Java心得总结三】Java泛型上——初识泛型

    一.函数参数与泛型比较 泛型(generics),从字面的意思理解就是泛化的类型,即参数化类型.泛型的作用是什么,这里与函数参数做一个比较: 无参数的函数: public int[] newIntAr ...

  10. 初识Java泛型以及桥接方法

    泛型的由来 在编写程序时,可能会有这样的需求:容器类,比如java中常见的list等.为了使容器可以保存多种类型的数据,需要编写多种容器类,每一个容器类中规定好了可以操作的数据类型.此时可能会有Int ...

随机推荐

  1. angularjs中的绑定策略“@”,“=”,“&”实例

    <!DOCTYPE html> <html lang="zh-CN" ng-app="app"> <head> <me ...

  2. 《Linux内核分析》 week4作业-使用嵌入式汇编调用一个系统调用

    一.fork的嵌入式汇编执行 #include <stdio.h> #include <unistd.h> int main(){ pid_t pid; asm volatil ...

  3. cmd命名设置成全局

    如在jsdoc里.想要把jsdoc命名设置成全局.只要把环境变量里面的用户变量里面的path变量值增加 C:\Program Files\nodejs;E:\Program Files (x86)\j ...

  4. Android应用----如何让应用全屏

    一般Android的应用启动时都有欢迎界面,类似QQHD启动那样.比较大方绚丽.心动不如行动,有时间自己也来实现类似的效果,嘿嘿.    观察发现QQHD的欢迎界面是全屏的,这个好办.下面就Andro ...

  5. git clone 远程分支

    先初始化一个git 仓库  命令:git init git clone 相应的地址 这样就会形成一个.git 隐藏文件夹 一定要注意的,要进入到子文件夹去git checkout feature/0. ...

  6. xml代码

    修改和删除: <?php$doc=new DOMDocument();$doc->load("php.xml");$root=$doc->documentElem ...

  7. IO定时器

    IoInitializeTimer 初始化定时器 IoStartTime 开启定时器 IoStopTimer 停止定时器 回调函数 VOID IoTimer( __in struct DEVICE_O ...

  8. 可选头 IMAGE_OPTIONAL_HEADER

    //IMAGE_OPTIONAL_HEADER结构(可选映像头) typedef struct _IMAGE_OPTIONAL_HEADER { // // Standard fields. // W ...

  9. 学习微信小程序之css17clearfix原理

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  10. ural 1671 Anansi's Cobweb

    这道题是并差集的简单应用 #include <cstdio> #include <cstring> #include <algorithm> #define max ...