Сообщения

Сообщения за июль, 2024

DSA: Arrays

Изображение
1. Best Score:  Given an array, write a function to get first, second best scores from the array and return it in new array. myArray = { 84 , 85 , 86 , 87 , 85 , 90 , 85 , 83 , 23 , 45 , 84 , 1 , 2 , 0 } firstSecond ( myArray ) // {90, 87}   package test; import java.util.Arrays; public class Main { public static void main (String[] args) { int [] arr = { 5 , 91 , 15 , 3 , 90 , 8 , 79 , 91 , 13 }; System. out .println(Arrays. toString ( findTopTwoScores (arr))); } public static int [] findTopTwoScores ( int [] array) { int [] result = new int [ 2 ]; int first = array[ 0 ]; int second = first; for ( int i = 1 ; i < array. length ; i++) { if (array[i] > first) { second = first; first = array[i]; } else if (array[i] > second && array[i] < first) { second = array[i]; } } result[ 0 ] = first; re...

DSA: Big O Notation

Изображение
1. Time Complexity  2. Space Complexity

Generics questions

 Question 1: package generics; import java.util.ArrayList; import java.util.Arrays; import java.util.List; public class Main { public static void main (String[] args) { List<?> list = Arrays. asList ( 1 , "hello" , 2.2 ); List<Object> list2 = list; } // public static void reverse(List<?> list) { // List<Object> tmp = new ArrayList<>(list); // for (int i = 0; i < list.size(); i++) { // list.set(i, tmp.get(list.size() - i - 1)); // compile-time error } // } // } public static void foo2 (List<?> list) { List<?> tmp = new ArrayList<>(list); for ( int i = 0 ; i < list.size(); i++) { list.set(i, tmp.get(list.size() - i - 1 )); } } public static void foo (List<?> list) { rev (list); } private static < T > void rev (List< T > list) { List< T > tmp = new ArrayList<>(list...

MultiThreading

Изображение
    package com.appsdeveloperblog.ws; import java.util.ArrayList; import java.util.Random; public class ListWorker3 { Random random = new Random(); ArrayList<Integer> list1 = new ArrayList<>(); ArrayList<Integer> list2 = new ArrayList<>(); public synchronized void addToList1 () { System. out .println(Thread. currentThread ().getName() + " : addToList1" ); try { Thread. sleep ( 1 ); } catch (Exception e) { e.printStackTrace(); } list1 .add( random .nextInt( 100 )); } public synchronized void addToList2 () { System. out .println(Thread. currentThread ().getName() + " : addToList2" ); try { Thread. sleep ( 1 ); } catch (Exception e) { e.printStackTrace(); } list2 .add( random .nextInt( 100 )); } public void assign () { for ( int i = 0 ; i < 1000 ; i++) { addToList1(...