Ky tutorial do të shpjegojë Kërkimin Binar & Kërkimi binar rekursiv në Java së bashku me algoritmin e tij, zbatimin dhe kodin binar të kërkimit Java:
Kërkimi binar në Java është një teknikë që përdoret për të kërkuar një vlerë ose çelës të synuar në një koleksion. Është një teknikë që përdor teknikën "përça dhe sundo" për të kërkuar një çelës.
Koleksioni në të cilin do të aplikohet kërkimi binar për të kërkuar një çelës duhet të renditet në rend rritës.
Zakonisht, shumica e gjuhëve të programimit mbështesin teknikat e kërkimit linear, të kërkimit binar dhe të hashimit që përdoren për të kërkuar të dhëna në koleksion. Ne do të mësojmë hashing në tutorialet tona të mëvonshme.
Kërkimi binar në Java
Kërkimi linear është një teknikë bazë. Në këtë teknikë, vargu përshkohet në mënyrë sekuenciale dhe çdo element krahasohet me çelësin derisa të gjendet çelësi ose të arrihet fundi i grupit.
Kërkimi linear përdoret rrallë në aplikime praktike. Kërkimi binar është teknika më e përdorur pasi është shumë më e shpejtë se një kërkim linear.
Java ofron tre mënyra për të kryer një kërkim binar:
- Përdorimi qasja përsëritëse
- Përdorimi i një qasjeje rekursive
- Përdorimi i metodës Arrays.binarySearch ().
Në këtë tutorial, ne do të zbatojmë dhe diskutojmë të gjitha këto 3 metoda.
Algoritmi për kërkimin binar në Java
Në binarmetoda e kërkimit, koleksioni ndahet në mënyrë të përsëritur në gjysmë dhe elementi kyç kërkohet në gjysmën e majtë ose të djathtë të koleksionit, në varësi të faktit nëse çelësi është më i vogël ose më i madh se elementi i mesit të koleksionit.
Një Algoritëm i thjeshtë i Kërkimit Binar është si më poshtë:
- Llogaritni elementin e mesit të koleksionit.
- Krahaso artikujt kyç me elementin mes.
- 8>Nëse çelësi = elementi i mesëm, atëherë kthejmë pozicionin e indeksit të mesit për çelësin e gjetur.
- Else If key > elementi i mesit, atëherë çelësi qëndron në gjysmën e djathtë të koleksionit. Kështu përsëritni hapat 1 deri në 3 në gjysmën e poshtme (djathtas) të koleksionit.
- Tasti tjetër elementi i mesit, atëherë çelësi është në gjysmën e sipërme të koleksionit. Prandaj ju duhet të përsërisni kërkimin binar në gjysmën e sipërme.
Siç mund ta shihni nga hapat e mësipërm, në kërkimin binar, gjysma e elementeve në koleksion injorohen menjëherë pas krahasimit të parë.
Vini re se e njëjta sekuencë hapash vlen për kërkimin binar përsëritës dhe rekurziv.
Le të ilustrojmë algoritmin e kërkimit binar duke përdorur një shembull.
Për shembull , marrim grupin e mëposhtëm të renditur prej 10 elementesh.
Le të llogarisim vendndodhjen e mesme të grupit.
Mid = 0+9/2 = 4
#1) Çelësi = 21
Së pari, ne do të krahasojmë vlerën e çelësit me elementi [mid] dhe gjejmë se vlera e elementit nëmid = 21.
Kështu gjejmë atë çelës = [mesi]. Prandaj, çelësi gjendet në pozicionin 4 në grup.
#2) Çelësi = 25
Së pari krahasojmë çelësin vlera deri në mes. Si (21 25), ne do të kërkojmë drejtpërdrejt për çelësin në gjysmën e sipërme të grupit.
Tani përsëri do të gjejmë mesin për gjysmën e sipërme të grupi.
Mid = 4+9/2 = 6
Vlera në vendndodhjen [mid] = 25
Tani ne krahasoni elementin kryesor me elementin e mesit. Pra (25 == 25), prandaj kemi gjetur çelësin në vendndodhjen [mid] = 6.
Kështu e ndajmë në mënyrë të përsëritur grupin dhe duke krahasuar elementin kyç me mid, vendosim se në cilën gjysmë do të kërkoni për çelësin. Kërkimi binar është më efikas për sa i përket kohës dhe korrektësisë dhe është gjithashtu shumë më i shpejtë.
Zbatimi i Kërkimit Binar Java
Duke përdorur algoritmin e mësipërm, le të implementojmë një program kërkimi binar në Java duke përdorur qasje përsëritëse. Në këtë program, ne marrim një grup shembull dhe kryejmë kërkimin binar në këtë grup.
import java.util.*; class Main{ public static void main(String args[]){ int numArray[] = {5,10,15,20,25,30,35}; System.out.println("The input array: " + Arrays.toString(numArray)); //key to be searched int key = 20; System.out.println("\nKey to be searched=" + key); //set first to first index int first = 0; //set last to last elements in array int last=numArray.length-1; //calculate mid of the array int mid = (first + last)/2; //while first and last do not overlap while( first = last ){ //if the mid key, then key to be searched is in the first half of array if ( numArray[mid] last ){ System.out.println("Element is not found!"); } } }
Output:
Sarreti hyrës: [5, 10, 15, 20 , 25, 30, 35]
Çelësi për tu kërkuar=20
Elementi gjendet në indeksin: 3
Programi i mësipërm tregon një qasje përsëritëse të kërkimit binar. Fillimisht deklarohet një grup, më pas përcaktohet një çelës që do të kërkohet.
Pas llogaritjes së mesit të grupit, çelësi krahasohet me elementin mid. Pastaj në varësi të faktit nëseçelësi është më i vogël ose më i madh se çelësi, çelësi kërkohet përkatësisht në gjysmën e poshtme ose të sipërme të grupit.
Kërkimi binar rekurziv në Java
Mund të kryeni gjithashtu një kërkim binar duke përdorur teknikën e rekursionit. Këtu, metoda e kërkimit binar thirret në mënyrë rekursive derisa të gjendet çelësi ose të shterohet e gjithë lista.
Programi që zbaton një kërkim binar rekurziv është dhënë më poshtë:
import java.util.*; class Main{ //recursive method for binary search public static int binary_Search(int intArray[], int low, int high, int key){ //if array is in order then perform binary search on the array if (high>=low){ //calculate mid int mid = low + (high - low)/2; //if key =intArray[mid] return mid if (intArray[mid] == key){ return mid; } //if intArray[mid] > key then key is in left half of array if (intArray[mid] > key){ return binary_Search(intArray, low, mid-1, key);//recursively search for key }else //key is in right half of the array { return binary_Search(intArray, mid+1, high, key);//recursively search for key } } return -1; } public static void main(String args[]){ //define array and key int intArray[] = {1,11,21,31,41,51,61,71,81,91}; System.out.println("Input List: " + Arrays.toString(intArray)); int key = 31; System.out.println("\nThe key to be searched:" + key); int high=intArray.length-1; //call binary search method int result = binary_Search(intArray,0,high,key); //print the result if (result == -1) System.out.println("\nKey not found in given list!"); else System.out.println("\nKey is found at location: "+result + " in the list"); } }
Dalja:
Lista e hyrjes: [1, 11, 21, 31, 41, 51, 61, 71, 81, 91
Çelësi që do të kërkohet :
Çelësi gjendet në vendndodhjen: 3 në listë
Duke përdorur metodën Arrays.binarySearch ().
Klasa Arrays në Java ofron një metodë 'binarySearch ()' që kryen kërkimin binar në grupin e dhënë. Kjo metodë merr grupin dhe çelësin që do të kërkohet si argumente dhe kthen pozicionin e çelësit në grup. Nëse çelësi nuk gjendet, atëherë metoda kthen -1.
Shembulli i mëposhtëm zbaton metodën Arrays.binarySearch ().
import java.util.Arrays; class Main{ public static void main(String args[]){ //define an array int intArray[] = {10,20,30,40,50,60,70,80,90}; System.out.println("The input Array : " + Arrays.toString(intArray)); //define the key to be searched int key = 50; System.out.println("\nThe key to be searched:" + key); //call binarySearch method on the given array with key to be searched int result = Arrays.binarySearch(intArray,key); //print the return result if (result 0) System.out.println("\nKey is not found in the array!"); else System.out.println("\nKey is found at index: "+result + " in the array."); } }
Output:
Grupi i hyrjes : [10, 20, 30, 40, 50, 60, 70, 80, 90]
Çelësi që do të kërkohet:50
Çelësi gjendet në indeksin: 4 në grup.
Pyetjet e bëra më shpesh
P #1) Si të shkruani një kërkim binar ?
Përgjigje: Kërkimi binar zakonisht kryhet duke e ndarë grupin në gjysma. Nëse çelësi që do të kërkohet është më i madh se elementi i mesit,atëherë gjysma e sipërme e grupit kërkohet duke e ndarë dhe kërkuar më tej nëngarkimin derisa të gjendet çelësi.
Ngjashëm, nëse çelësi është më i vogël se elementi i mesit, atëherë çelësi kërkohet në pjesën e poshtme gjysma e grupit.
P #2) Ku përdoret kërkimi binar?
Përgjigje: Kërkimi binar përdoret kryesisht për të kërkuar një të dhënat e renditura në aplikacionet softuerike veçanërisht kur hapësira e memories është kompakte dhe e kufizuar.
P #3) Cili është O i madh i kërkimit binar?
Përgjigja : Kompleksiteti kohor i kërkimit binar është O (logn) ku n është numri i elementeve në grup. Kompleksiteti hapësinor i kërkimit binar është O (1).
P #4) A është kërkimi binar rekurziv?
Përgjigje: Po. Meqenëse kërkimi binar është një shembull i një strategjie përça dhe sundo dhe mund të zbatohet duke përdorur rekursion. Mund ta ndajmë grupin në gjysma dhe të thërrasim të njëjtën metodë për të kryer kërkimin binar vazhdimisht.
P #5) Pse quhet kërkim binar?
Përgjigja: Algoritmi binar i kërkimit përdor një strategji "përça dhe sundo" që e pret në mënyrë të përsëritur grupin në gjysmë ose dy pjesë. Kështu ai emërtohet si kërkim binar.
Përfundim
Kërkimi binar është teknika e kërkimit e përdorur shpesh në Java. Kërkesa që të kryhet një kërkim binar është që të dhënat duhet të renditen në rend rritës.
Një kërkim binar mund të jetëzbatohet ose duke përdorur një qasje përsëritëse ose rekursive. Klasa e vargjeve në Java ofron gjithashtu metodën 'binarySearch' që kryen një kërkim binar në një varg.
Në mësimet tona të mëvonshme, ne do të eksplorojmë teknika të ndryshme të renditjes në Java.
23>