欢迎访问 生活随笔!

尊龙凯时首页

当前位置: 尊龙凯时首页 > 编程资源 > 编程问答 >内容正文

编程问答

java中printarray和selectsort方法-尊龙凯时首页

发布时间:2024/10/14 编程问答 7 豆豆
尊龙凯时首页 收集整理的这篇文章主要介绍了 java中printarray和selectsort方法_算法题(一) 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

目录

1 左神部分集锦

2 leetcode前150题

3 牛客网剑指offer

4 javag

5 题目中的细节处理

1 左神部分集锦

1.1 code01_findnumber_b_in_a

在有序数组a中,找到b中(不)存在的数。public class code01_findnumber_b_in_a {

// 生成随机数组

public static int[] generaterandomarray(int maxsize, int maxvalue) {

int[] arr = new int[(int) ((maxsize 1) * math.random())];

for (int i = 0; i < arr.length; i ) {

arr[i] = (int) ((maxvalue 1) * math.random()) - (int) (maxvalue * math.random());

}

return arr;

}

// 二分法

public static int[] binary(int[] a, int[] b) {

if (a == null || b == null) {

return null;

}

int[] help = new int[b.length];

for (int i = 0; i < b.length; i ) {

int l = 0;

int r = a.length - 1;

while (l <= r) {

int mid = l (r - l) / 2;

if (b[i] < a[mid]) {

r = mid - 1;

} else if (b[i] > a[mid]) {

l = mid 1;

} else {

break;

}

}

if (l > r) {

help[i] = b[i];// 不在a中数

}

}

return help;

}

// 类似外排的方法

public static list waipai(int[] a, int[] b) {

arrays.sort(b);

list help = new arraylist<>();

int p1 = 0;

int p2 = 0;

while (p1 < a.length && p2 < b.length) {

if (a[p1] < b[p2]) {

p1 ;

} else if (a[p1] > b[p2]) {

p2 ;

} else {

help.add(b[p2]); //在a中的数

p1 ;

p2 ;

}

}

return help;

}

public static void main(string[] args) {

int amaxsize = 10;

int bmaxsize = 10;

int maxvalue = 100;

int[] a = generaterandomarray(amaxsize, maxvalue);

int[] b = generaterandomarray(bmaxsize, maxvalue);

//int[] a = { 1, 2, 3, 4, 5 };

//int[] b = { 1, 6, 3 ,5};

int[] res = binary(a, b);

//list list = waipai(a, b);

system.out.println(arrays.tostring(a));

system.out.println(arrays.tostring(b));

system.out.println(arrays.tostring(res));

//for (integer integer : list) {

//system.out.print(integer " ");

//}

}

}

1.2 code02_bubblesortpublic class code02_bubblesort {

public static void bubblesort(int[] arr) {

if (arr == null || arr.length < 2) {

return;

}

for (int i = arr.length - 1; i > 0; i--) {

for (int j = 0; j < i; j ) {

if (arr[j] > arr[j 1]) {

swap(arr, j, j 1);

}

}

}

}

public static void swap(int[] arr, int a, int b) {

int temp = arr[a];

arr[a] = arr[b];

arr[b] = temp;

}

public static int[] generaterandomarray(int maxsize, int maxvalue) {

int[] arr = new int[(int)((maxsize 1) * math.random())];

for(int i =0; i < arr.length; i ) {

arr[i] = (int)((maxvalue 1)*math.random()) - (int)(maxvalue * math.random());

}

return arr;

}

public static void main(string[] args) {

int maxsize = 20;

int maxvalue = 100;

int[] arr = generaterandomarray(maxsize, maxvalue);

system.out.println(arrays.tostring(arr));

bubblesort(arr);

system.out.println(arrays.tostring(arr));

}

}

1.3 code03_insertsortpublic class code03_insertsort {

public static void insertsort(int[] arr) {

if (arr == null || arr.length < 2) {

return;

}

for (int i = 1; i < arr.length; i ) {

for (int j = i - 1; j > -1; j--) {

if (arr[j] > arr[j 1]) {

swap(arr, j, j 1);

}

}

}

}

public static void swap(int[] arr, int a, int b) {

int temp = arr[a];

arr[a] = arr[b];

arr[b] = temp;

}

public static void main(string[] args) {

int[] a = {4,1,2,7,40,35,51};

system.out.println(arrays.tostring(a));

insertsort(a);

system.out.println(arrays.tostring(a));

}

}

1.4 code04_selectsortpublic class code04_selectsort {

public static void selectsort(int[] arr) {

if (arr == null || arr.length < 2) {

return;

}

for (int i = 0; i < arr.length; i ) {

int minindex = i;

for (int j = i 1; j < arr.length; j ) {

if (arr[j] < arr[minindex]) {

minindex = j;

}

}

swap(arr, i, minindex);

}

}

public static void swap(int[] arr, int a, int b) {

int temp = arr[a];

arr[a] = arr[b];

arr[b] = temp;

}

public static int[] generaterandomarray(int maxsize, int maxvalue) {

int[] arr = new int[(int)((maxsize 1)*math.random())];

for(int i=0;i

arr[i] = (int)((maxvalue 1)*math.random())-(int)(maxvalue * math.random());

}

return arr;

}

public static void main(string[] args) {

int[] arr = generaterandomarray(10, 50);

system.out.println(arrays.tostring(arr));

selectsort(arr);

system.out.println(arrays.tostring(arr));

}

}

1.5 code05_mergesortpublic class code05_mergesort {

public static void mergesort(int[] arr) {

if (arr == null || arr.length < 2) {

return;

}

mergesort(arr, 0, arr.length - 1);

}

private static void mergesort(int[] arr, int l, int r) {

if (l == r) {

return;

}

int mid = l (r - l) / 2;

mergesort(arr, l, mid);

mergesort(arr, mid 1, r);

merge(arr, l, mid, r);

}

private static void merge(int[] arr, int l, int mid, int r) {

int[] help = new int[r - l 1];

int index = 0;

int p1 = l;

int p2 = mid 1;

while (p1 <= mid && p2 <= r) {

help[index ] = arr[p1] < arr[p2] ? arr[p1 ] : arr[p2 ];

}

while (p1 <= mid) {

help[index ] = arr[p1 ];

}

while (p2 <= r) {

help[index ] = arr[p2 ];

}

for (int i = 0; i < help.length; i ) {

arr[l i] = help[i];

}

}

public static void main(string[] args) {

// todo auto-generated method stub

int[] arr = new int[] { 2, 5, 1, 3, 6, 2, 1 };

mergesort(arr);

system.out.println(arrays.tostring(arr));

}

}

1.6 code06_smallnumbersum

小和问题:在一个数组中,每一个数左边比当前数小的数累加起来,叫做这个数组的小和。public class code06_smallnumbersum {

public static int getsum(int[] arr) {

if(arr==null || arr.length < 2) {

return 0;

}

return mergesort(arr, 0, arr.length - 1);

}

private static int mergesort(int[] arr, int l, int r) {

if(l == r) {

return 0;

}

int mid = l (r - l) / 2;

return mergesort(arr, l, mid) mergesort(arr, mid 1, r) merge(arr, l, mid, r);

}

private static int merge(int[] arr, int l, int mid, int r) {

int sum = 0;

int[] help = new int[r - l 1];

int index = 0;

int p1 = l;

int p2 = mid 1;

while(p1 <= mid && p2 <= r) {

sum = arr[p1] < arr[p2] ? (r - p2 1) * arr[p1] : 0;

help[index ] = arr[p1] < arr[p2] ? arr[p1 ] : arr[p2 ];

}

while(p1 <= mid) {

help[index ] = arr[p1];

}

while(p2 <= r) {

help[index ] = arr[p2 ];

}

for(int i =0 ; i < help.length; i ) {

arr[l i] = help[i];

}

return sum;

}

public static void main(string[] args) {

// todo auto-generated method stub

int[] arr = new int[]{1,3,4,2,5};

system.out.print(getsum(arr));

}

}

// output:16

1.7 code07_quicksort

随机快排public class code07_quicksort {

public static void quicksort(int[] arr) {

if (arr == null || arr.length < 2) {

return;

}

quicksort(arr, 0, arr.length - 1);

}

private static void quicksort(int[] arr, int l, int r) {

if (l < r) {

swap(arr, l (int) (math.random() * (r - l 1)), r);

int[] p = partition(arr, l, r);

quicksort(arr, l, p[0] - 1);

quicksort(arr, p[1] 1, r);

}

}

private static int[] partition(int[] arr, int l, int r) {

int less = l-1;

int more = r;

while (l < more) {

if (arr[l] < arr[r]) {

swap(arr, l , less);

} else if (arr[l] > arr[r]) {

swap(arr, l, --more);

} else {

l ;

}

}

swap(arr, more, r);

return new int[] { less 1, more };

}

public static int[] generaterandomarray(int maxsize, int maxvalue) {

int[] arr = new int[(int) ((maxsize 1) * math.random())];

for (int i = 0; i < arr.length; i ) {

arr[i] = (int) ((maxvalue 1) * math.random()) - (int) (maxvalue * math.random());

}

return arr;

}

private static void swap(int[] arr, int a, int b) {

int temp = arr[a];

arr[a] = arr[b];

arr[b] = temp;

}

/**

* @param args

*/

public static void main(string[] args) {

// todo auto-generated method stub

int[] arr = generaterandomarray(20, 20);

system.out.println(arrays.tostring(arr));

quicksort(arr);

system.out.println(arrays.tostring(arr));

}

}

1.8 code08_heapsortpublic class code08_heapsort {

public static void heapsort(int[] arr) {

if (arr == null || arr.length < 2) {

return;

}

//���������

for (int i = 0; i < arr.length; i ) {

heapinsert(arr, i);

}

int size = arr.length - 1;

swap(arr, size, 0);

while(size > 0) {

heapify(arr, 0, size);

swap(arr, --size, 0);

}

}

// ��������β�������ϱƚ�

private static void heapinsert(int[] arr, int index) {

while (arr[index] > arr[(index - 1) / 2]) {

swap(arr, index, (index - 1) / 2);

index = (index - 1) / 2;

}

}

// �ѷ�Ԫ�ظı䣬���±ƚ�

public static void heapify(int[] arr, int index, int size) {

int left = index * 2 1;

while(left < size) {

int largest = left 1 < size && arr[left] < arr[left 1] ? left 1: left;

largest =  arr[largest] > arr[index]? largest: index;

if(largest == index) {

break;

}

swap(arr, largest, index);

index = largest;

left = index * 2 1;

}

}

public static void swap(int[] arr, int a, int b) {

int temp = arr[a];

arr[a] = arr[b];

arr[b] = temp;

}

/**

* @param args

*/

public static void main(string[] args) {

// todo auto-generated method stub

int[] arr = new int[]{3, 6, 3, 2, 9, 0};

system.out.println(arrays.tostring(arr));

heapsort(arr);

system.out.println(arrays.tostring(arr));

}

}

1.9 code09_mediumnumber

在一段数据流中,找到中位数public class code09_mediumnumber {

private int cnt = 0;

private priorityqueue low = new priorityqueue();

private priorityqueue high = new priorityqueue(new comparator() {

public int compare(integer o1, integer o2) {

return o2.compareto(o1);

}

});

public void insert(integer num) {

cnt ;

if((cnt & 1) == 1) {

if(!low.isempty() && num > low.peek()) {

low.offer(num);

num = low.poll();

}

high.offer(num);

}else {

if(!high.isempty() && num < high.peek()) {

high.offer(num);

num = high.poll();

}

low.offer(num);

}

}

public double germidian() {

double res = 0;

if((cnt & 1) == 1) {

res = high.peek();

}else {

res = (high.peek() low.peek()) / 2.0;

}

return res;

}

}

1.10 code10_maxgap

给定一个数组,求如果排序之后,相邻两个数的最大差值,时间复杂度o(n),不能基于比较的排序。public class code10_maxgap {

public static int maxgap(int[] nums) {

if (nums == null || nums.length < 2) {

return 0;

}

int len = nums.length;

int min = integer.max_value;

int max = integer.min_value;

for (int i = 0; i < len; i ) {

min = math.min(min, nums[i]);

max = math.max(max, nums[i]);

}

if (min == max) {

return 0;

}

boolean[] hasnum = new boolean[len 1];

int[] maxs = new int[len 1];

int[] mins = new int[len 1];

int bid;

for (int i = 0; i < len; i ) {

bid = bucket(nums[i], len, min, max);

mins[bid] = hasnum[bid] ? math.min(mins[bid], nums[i]) : nums[i];

maxs[bid] = hasnum[bid] ? math.max(maxs[bid], nums[i]) : nums[i];

hasnum[bid] = true;

}

int res = 0;

int lastmax = maxs[0];

for (int i = 1; i <= len; i ) {

if (hasnum[i]) {

res = math.max(res, mins[i] - lastmax);

lastmax = maxs[i];

}

}

return res;

}

private static int bucket(long num, long len, long min, long max) {

return (int) ((num - min) * len / (max - min));

}

/**

* @param args

*/

public static void main(string[] args) {

// todo auto-generated method stub

int[] arr = new int[]{1,5,2,1,5,2,7,6,9,2};

//arrays.sort(arr);

system.out.println(arrays.tostring(arr));

system.out.print(maxgap(arr));

}

}

1.11 code11_array_stack_queue

用数组结构实现大小固定的队列和栈。

注意队列和栈需要的类属性和指针的变化。public class code11_array_stack_queue {

public static class arraystack {

private integer[] arr;

private integer size;// ջ��ָ��

public arraystack(int initsize) {

if (initsize < 0) {

throw new illegalargumentexception("size is less than 0");

}

arr = new integer[initsize];

size = 0;

}

public integer peek() {

if (size == 0) {

return null;

}

return arr[size - 1];

}

public void push(int obj) {

if (size == arr.length) {

throw new arrayindexoutofboundsexception("the stack is full");

}

arr[size ] = obj;

}

public integer pop() {

if (size == 0) {

throw new arrayindexoutofboundsexception("the stack is empty");

}

return arr[--size];

}

}

public static class arrayqueue {

private integer[] arr;

private integer size;

private integer first;

private integer last;

public arrayqueue(int initsize) {

if (initsize < 0) {

throw new illegalargumentexception("size is less than 0");

}

arr = new integer[initsize];

size = 0;

first = 0;

last = 0;

}

public integer peek() {

if (size == 0) {

return null;

}

return arr[first];

}

public void push(int obj) {

if (size == arr.length) {

throw new arrayindexoutofboundsexception("the queue is full");

}

size ;

arr[last] = obj;

last = last == arr.length - 1 ? 0 : last 1;

}

public integer poll() {

if (size == 0) {

throw new arrayindexoutofboundsexception("the queue is empty");

}

size--;

int temp = arr[first];

first = first == arr.length - 1 ? 0 : first 1;

return temp;

}

}

}

1.12 code12_getminstack

实现一个特殊的栈,在栈的基础上增加返回最小元素的操作。

· 思路:准备两个栈,data栈正常压栈,min栈需要比较当前数和栈顶数的大小。public class code12_getminstack {

private stack stackdata;

private stack stackmin;

public code12_getminstack() {

this.stackdata = new stack();

this.stackmin = new stack();

}

public void push(int newnum) {

if (this.stackmin.isempty()) {

this.stackmin.push(newnum);

} else if (newnum < this.getmin()) {

this.stackmin.push(newnum);

} else {

int newmin = this.stackmin.peek();

this.stackmin.push(newmin);

}

this.stackdata.push(newnum);

}

public integer getmin() {

if (this.stackmin.isempty()) {

throw new runtimeexception("your stack is empty");

}

return this.stackmin.peek();

}

}

1.13 code13_stack_convert_queuepublic class code13_stack_convert_queue {

public static class stacktoqueue{

private stack stackpush;

private stack stackpop;

public stacktoqueue() {

this.stackpush = new stack();

this.stackpop = new stack();

}

public void push(int pushint) {

stackpush.push(pushint);

}

public int poll() {

//empty()��isempty������ͬ��

if(stackpop.isempty() && stackpush.isempty()) {

throw new runtimeexception("queue is empty");

}else if(stackpop.isempty()) {

while(!stackpush.isempty()) {

stackpop.push(stackpush.pop());

}

}

return stackpop.pop();

}

public int peek() {

if(stackpop.isempty() && stackpush.isempty()) {

throw new runtimeexception("queue is empty");

}else if(stackpop.isempty()) {

while(!stackpush.isempty()) {

stackpop.push(stackpush.pop());

}

}

return stackpop.peek();

}

}

public static class queuetostack{

private queue queue;

private queue help;

public queuetostack() {

this.queue = new linkedlist();

this.help = new linkedlist();

}

public void push(int pushint) {

queue.offer(pushint);

}

public int peek() {

if(queue.isempty()) {

throw new runtimeexception("stack is empty");

}

while(queue.size() != 1) {

help.offer(queue.poll());

}

int res = queue.poll();

queue temp = help;

help = queue;

queue = temp;

return res;

}

}

}

1.14 code14_printmatrixspiralorderpublic class code14_printmatrixspiralorder {

public static void printmatrix(int[][] matrix) {

int tr = 0;

int tc = 0;

int dr = matrix.length - 1;// ����

int dc = matrix[0].length - 1;// ����

while (tr <= dr && tc <= dc) {

printedge(matrix, tr , tc , dr--, dc--);

}

}

public static void printedge(int[][] m, int tr, int tc, int dr, int dc) {

if (tr == dr) {

for (int i = tc; i <= dc; i ) {

system.out.print(m[tr][i] " ");

}

} else if (tc == dc) {

for (int i = tr; i <= dr; i ) {

system.out.print(m[i][tc] " ");

}

} else {

int curc = tc;

int curr = tr;

while (curc != dc) {

system.out.print(m[tr][curc] " ");

curc ;

}

while (curr != dr) {

system.out.print(m[curr][dc] " ");

curr ;

}

while (curc != tc) {

system.out.print(m[dr][curc] " ");

curc--;

}

while (curr != tr) {

system.out.print(m[curr][tc] " ");

curr--;

}

}

}

public static void main(string[] args) {

// todo auto-generated method stub

int[][] matrix = {{1, 2, 3, 4}, {5, 6, 7, 8}, {9, 10, 11, 12}, {13, 14, 15, 16}};

printmatrix(matrix);

}

}

1.15 code15_rotatematrixpublic class code15_rotatematrix {

public static void rotate(int[][] matrix) {

int ax = 0;

int ay = 0;

int bx = matrix.length - 1;

int by = matrix[0].length - 1;

while(ax < bx) {

rotateedge(matrix, ax , ay , bx--, by--);

}

}

public static void rotateedge(int[][] m, int ax, int ay, int bx, int by) {

int times = by - ay;

int tmp = 0;

for(int i = 0; i != times; i ) {

tmp = m[ax][ay i];

m[ax][ay i] = m[bx - i][ay];

m[bx - i][ay] = m[bx][by - i];

m[bx][by - i] = m[ax i][by];

m[ax i][by] = tmp;

}

}

public static void printmatrix(int[][] matrix) {

for(int i = 0; i < matrix.length; i ) {

for(int j = 0; j < matrix[0].length; j ) {

system.out.print(matrix[i][j] " ");

}

system.out.println();

}

}

public static void main(string[] args) {

// todo auto-generated method stub

int[][] matrix = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}};

printmatrix(matrix);

rotate(matrix);

system.out.println("==============");

printmatrix(matrix);

}

}

1.16 code16_zigzagprintmatrixpublic class code16_zigzagprintmatrix {

public static void printmatrixzigzag(int[][] matrix) {

int tr = 0;

int tc = 0;

int dr = 0;

int dc = 0;

int endr = matrix.length - 1;

int endc = matrix[0].length - 1;

boolean fromup = false;

while (tr != endr 1) {

printlevel(matrix, tr, tc, dr, dc, fromup);

tr = tc == endc ? tr 1 : tr;

tc = tc == endc ? tc : tc 1;

dc = dr == endr ? dc 1 : dc;

dr = dr == endr ? dr : dr 1;

fromup = !fromup;

}

system.out.println();

}

public static void printlevel(int[][] m, int tr, int tc, int dr, int dc,

boolean f) {

if (f) {

while (tr != dr 1) {

system.out.print(m[tr ][tc--] " ");

}

} else {

while (dr != tr - 1) {

system.out.print(m[dr--][dc ] " ");

}

}

}

public static void main(string[] args) {

// todo auto-generated method stub

int[][] matrix = { { 1, 2, 3, 4 }, { 5, 6, 7, 8 }, { 9, 10, 11, 12 } };

printmatrixzigzag(matrix);

}

}

1.17 code17_findnuminsortedmatrixpublic class code17_findnuminsortedmatrix {

public static boolean iscontains(int[][] matrix, int k) {

int row = 0;

int col = matrix[0].length - 1;

while (row < matrix.length && col >= 0) {

if (matrix[row][col] == k) {

return true;

} else if (matrix[row][col] < k) {

row ;

} else {

col--;

}

}

return false;

}

public static void main(string[] args) {

// todo auto-generated method stub

int[][] matrix = new int[][] { { 0, 1, 2, 3, 4, 5, 6 }, // 0

{ 10, 12, 13, 15, 16, 17, 18 }, // 1

{ 23, 24, 25, 26, 27, 28, 29 }, // 2

{ 44, 45, 46, 47, 48, 49, 50 }, // 3

{ 65, 66, 67, 68, 69, 70, 71 }, // 4

{ 96, 97, 98, 99, 100, 111, 122 }, // 5

{ 166, 176, 186, 187, 190, 195, 200 }, // 6

{ 233, 243, 321, 341, 356, 370, 380 } // 7

};

int k = 233;

system.out.println(iscontains(matrix, k));

}

}

1.18 code18_ispalindromelistpublic class code18_ispalindromelist {

public static class node{

public int value;

public node next;

public node(int data) {

this.value = data;

}

}

//�۵�����

public static boolean ispalindrome(node head) {

if( head == null || head.next == null) {

return true;

}

node n1 = head;

node n2 = head;

while(n2.next != null && n2.next.next != null) {

n1 = n1.next;

n2 = n2.next.next;

}

//n1ϊ�е�

n2 = n1.next;

n1.next = null;

node n3 = null;

while(n2 != null) {

n3 = n2.next;

n2.next = n1;

n1 = n2;

n2 = n3;

}

n3 = n1;

n2 = head;

boolean res = true;

while(n1 != null && n2 != null) {

if(n1.value != n2.value) {

res = false;

break;

}

n1 = n1.next;

n2 = n2.next;

}

//��ԭ����

n1 = n3.next;

n3.next = null;

while(n1 != null) {

n2 = n1.next;

n1.next = n3;

n3 = n1;

n1 = n2;

}

return res;

}

}

1.19 code19_smallerequalbiggerpublic class code19_smallerequalbigger {

public static class node{

public int value;

public node next;

public node (int data) {

this.value = data;

}

}

public static node listpartition(node head, int pivot) {

if(head == null) {

return head;

}

node cur = head;

int i = 0;

while(cur != null) {

i ;

cur = cur.next;

}

node[] nodearr  = new node[i];

i = 0;

cur = head;

//������ת�ɽڵ�����

for(; i != nodearr.length; i ) {

nodearr[i] = cur;

cur = cur.next;

}

arrpartition(nodearr, pivot);

for(i = 1; i < nodearr.length; i ) {

nodearr[i -  1].next = nodearr[i];

}

nodearr[i - 1].next = null;

return nodearr[0];

}

public static void arrpartition (node[] nodearr, int pivot) {

int less = -1;

int more = nodearr.length;

int index = 0;

while(less < more) {

if(nodearr[index].value < pivot) {

swap(nodearr, index , less);

}else if(nodearr[index].value > pivot) {

swap(nodearr, index, --more);

}else {

index ;

}

}

}

public static void swap(node[] arr, int a, int b) {

node temp = arr[a];

arr[a] = arr[b];

arr[b] = temp;

}

}

1.20 code20_copylistwithrandompublic class code20_copylistwithrandom {

public static class node{

public int value;

public node next;

public node rand;

public node(int data) {

this.value = data;

}

}

//���븴�ƽڵ�

public static node copylistwithrand(node head) {

if(head == null) {

return null;

}

node cur = head;

node next = null;

while(cur != null) {

next = cur.next;

cur.next = new node(cur.value);

cur.next.next = next;

cur = next;

}

cur = head;

node curcopy = null;

while(cur != null) {

next = cur.next.next;

curcopy = cur.next;

curcopy.rand = cur.rand == null ? null : cur.rand.next;

cur = next;

}

node res = head.next;

cur = head;

while(cur != null) {

next = cur.next.next;

curcopy = cur.next;

cur.next = next;

curcopy.next = next != null ? next.next : null;

cur = next;

}

return res;

}

}

1.21 code21_findfirstintersectnodepublic class code21_findfirstintersectnode {

public static class node{

public int value;

public node next;

public node(int data) {

this.value = data;

}

}

public static node getintersectnode(node head1, node head2) {

if(head1 == null || head2 == null) {

return null;

}

node loop1 = getloopnode(head1);

node loop2 = getloopnode(head2);

if(loop1 == null && loop2 == null) {

return noloop(head1, head2);

}

if(loop1 != null && loop2 != null) {

return bothloop(head1, loop1, head2, loop2);

}

return null;

}

private static node bothloop(node head1, node loop1, node head2, node loop2) {

// todo �զ����ɵķ������

node cur1 = null;

node cur2 = null;

if(loop1 == loop2) {

cur1 = head1;

cur2 = head2;

int n = 0;

while(cur1 != loop1) {

n ;

cur1 = cur1.next;

}

while(cur2 != loop2) {

n--;

cur2 = cur2.next;

}

cur1 = n > 0 ? head1 : head2;

cur2 = cur1 == head1 ? head2 : head1;

n = math.abs(n);

while(n != 0) {

n--;

cur1 = cur1.next;

}

while(cur1 != cur2) {

cur1 = cur1.next;

cur2 = cur2.next;

}

return cur1;

}else {

cur1 = loop1.next;

while(cur1 != loop1) {

if(cur1 == loop2) {

return loop1;

}

cur1 = cur1.next;

}

return null;

}

}

private static node noloop(node head1, node head2) {

// todo �զ����ɵķ������

node cur1 = head1;

node cur2 = head2;

int n = 0;

while(cur1.next != null) {

n ;

cur1 = cur1.next;

}

while(cur2.next != null) {

n--;

cur2 = cur2.next;

}

if(cur1 != cur2) {

return null;

}

cur1 = n > 0 ? head1: head2;

cur2 = cur1 == head1 ? head2 : head1;

n = math.abs(n);

while(n != 0) {

n--;

cur1 = cur1.next;

}

while(cur1 != cur2) {

cur1 = cur1.next;

cur2 = cur2.next;

}

return cur1;

}

public static node getloopnode(node head) {

// todo �զ����ɵķ������

if(head == null || head.next == null || head.next.next == null) {

return null;

}

node n1 = head.next;

node n2 = head.next.next;

while(n1 != n2) {

if(n2.next == null || n2.next.next == null) {

return null;

}

n1 = n1.next;

n2 = n2.next.next;

}

n2 = head;

while(n1 != n2) {

n1 = n1.next;

n2 = n2.next;

}

return n1;

}

}

总结

以上是尊龙凯时首页为你收集整理的java中printarray和selectsort方法_算法题(一)的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得尊龙凯时首页网站内容还不错,欢迎将尊龙凯时首页推荐给好友。

网站地图