• Resolved Bakhshi

    (@bakhshi)


    Hello
    I’m going to use the array in this site:
    [ redundant link removed ]

    // Java program to find element closet to given target. 
    import java.util.*; 
    import java.lang.*; 
    import java.io.*; 
    
    class FindClosestNumber { 
    	
    	// Returns element closest to target in arr[] 
    	public static int findClosest(int arr[], int target) 
    	{ 
    		int n = arr.length; 
    
    		// Corner cases 
    		if (target <= arr[0]) 
    			return arr[0]; 
    		if (target >= arr[n - 1]) 
    			return arr[n - 1]; 
    
    		// Doing binary search 
    		int i = 0, j = n, mid = 0; 
    		while (i < j) { 
    			mid = (i + j) / 2; 
    
    			if (arr[mid] == target) 
    				return arr[mid]; 
    
    			/* If target is less than array element, 
    			then search in left */
    			if (target < arr[mid]) { 
    		
    				// If target is greater than previous 
    				// to mid, return closest of two 
    				if (mid > 0 && target > arr[mid - 1]) 
    					return getClosest(arr[mid - 1], 
    								arr[mid], target); 
    				
    				/* Repeat for left half */
    				j = mid;			 
    			} 
    
    			// If target is greater than mid 
    			else { 
    				if (mid < n-1 && target < arr[mid + 1]) 
    					return getClosest(arr[mid], 
    						arr[mid + 1], target);				 
    				i = mid + 1; // update i 
    			} 
    		} 
    
    		// Only single element left after search 
    		return arr[mid]; 
    	} 
    
    	// Method to compare which one is the more close 
    	// We find the closest by taking the difference 
    	// between the target and both values. It assumes 
    	// that val2 is greater than val1 and target lies 
    	// between these two. 
    	public static int getClosest(int val1, int val2, 
    										int target) 
    	{ 
    		if (target - val1 >= val2 - target) 
    			return val2;		 
    		else
    			return val1;		 
    	} 
    
    	// Driver code 
    	public static void main(String[] args) 
    	{ 
    		int arr[] = { 1, 2, 4, 5, 6, 6, 8, 9 }; 
    		int target = 11; 
    		System.out.println(findClosest(arr, target)); 
    	} 
    } 
    Output:
    9

    I completely replaced the code in the Calculated Field
    But output 9 didn’t show!

    What parts of this array are not known for the plugin?

    • This topic was modified 4 years, 10 months ago by Bakhshi.
    • This topic was modified 4 years, 10 months ago by Bakhshi.
    • This topic was modified 4 years, 10 months ago by Jan Dembowski.

    The page I need help with: [log in to see the link]

Viewing 1 replies (of 1 total)
Viewing 1 replies (of 1 total)
  • The topic ‘Help about array Find’ is closed to new replies.