Ako pridať prvok do poľa v jazyku Java?

Vzhľadom na pole veľkosti n je úlohou pridať prvok x do tohto poľa v jazyku Java. Veľkosť poľa sa v Jave nedá dynamicky meniť, ako sa to robí v C/C++. Preto na pridanie prvku do poľa je možné vykonať jednu z nasledujúcich metód:

  1. Vytvorením nového poľa:
    • Vytvorte nové pole veľkosti n+1, kde n je veľkosť pôvodného poľa.
    • Pridajte n prvkov pôvodného poľa do tohto poľa.
    • Pridajte nový prvok na n+1. pozíciu.
    • Vytlačte nové pole.

Nižšie je uvedená implementácia vyššie uvedeného prístupu:

Java




// Java Program to add an element in an Array> > import> java.io.*;> import> java.lang.*;> import> java.util.*;> > class> GFG {> > > // Function to add x in arr> > public> static> int> [] addX(> int> n,> int> arr[],> int> x)> > {> > int> i;> > > // create a new array of size n+1> > int> newarr[] => new> int> [n +> 1> ];> > > // insert the elements from> > // the old array into the new array> > // insert all elements till n> > // then insert x at n+1> > for> (i => 0> ; i newarr[i] = arr[i]; newarr[n] = x; return newarr; } // Driver code public static void main(String[] args) { int n = 10; int i; // initial array of size 10 int arr[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; // print the original array System.out.println('Initial Array: ' + Arrays.toString(arr)); // element to be added int x = 50; // call the method to add x in arr arr = addX(n, arr, x); // print the updated array System.out.println(' Array with ' + x + ' added: ' + Arrays.toString(arr)); } }>

 Output: Initial Array: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] Array with 50 added: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 50] 

Časová zložitosť: O(N)

Pomocný priestor: O(N)

  1. Použitím ArrayList ako prechodného úložiska:

Java




// Java Program to add an element in an Array> > > import> java.io.*;> > import> java.lang.*;> > import> java.util.*;> > > class> GFG {> > > // Function to add x in arr> > public> static> Integer[] addX(> int> n, Integer arr[],> int> x)> > {> > int> i;> > > // create a new ArrayList> > List arrlist> > => new> ArrayList(> > Arrays.asList(arr));> > > // Add the new element> > arrlist.add(x);> > > // Convert the Arraylist to array> > arr = arrlist.toArray(arr);> > > // return the array> > return> arr;> > }> > > // Driver code> > public> static> void> main(String[] args)> > {> > > int> n => 10> ;> > int> i;> > > // initial array of size 10> > Integer arr[]> > = {> 1> ,> 2> ,> 3> ,> 4> ,> 5> ,> 6> ,> 7> ,> 8> ,> 9> ,> 10> };> > > // print the original array> > System.out.println(> 'Initial Array: '> > + Arrays.toString(arr));> > > // element to be added> > int> x => 50> ;> > > // call the method to add x in arr> > arr = addX(n, arr, x);> > > // print the updated array> > System.out.println(> ' Array with '> + x> > +> ' added: '> > + Arrays.toString(arr));> > }> > }>

  Output:   Initial Array: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] Array with 50 added: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 50] 

Časová zložitosť: O(N)

Pomocný priestor: O(N)