• Skip to primary navigation
  • Skip to content
  • Skip to primary sidebar
  • Skip to secondary sidebar

GoHired

Interview Questions asked in Google, Microsoft, Amazon

Join WeekEnd Online Batch from 4-April-2020 on How to Crack Coding Interview in Just 10 Weeks : Fees just 20,000 INR

  • Home
  • Best Java Books
  • Algorithm
  • Internship
  • Certificates
  • About Us
  • Contact Us
  • Privacy Policy
  • Array
  • Stack
  • Queue
  • LinkedList
  • DP
  • Strings
  • Tree
  • Mathametical
  • Puzzles
  • Graph

Given a sorted array and a number x, find the pair in array whose sum is closest to x

November 17, 2014 by Dhaval Dave

Given a sorted array and a number x, find a pair in array whose sum is closest to x.

Examples:

Input: arr[] = {10, 22, 28, 29, 32, 40}, x = 54
Output: 22 and 32

A simple solution is to consider every pair and keep track of closest pair (absolute difference between pair sum and x is minimum). Finally print the closest pair. Time complexity of this solution is O(n2)

An efficient solution can find the pair in O(n) time. The idea is similar to method 2 of this post. Following is detailed algorithm.

#include <iostream>
#include <climits>
#include <cstdlib>
using namespace std;

// Prints the pair with sum cloest to x
void printClosest(int arr[], int n, int x)
{
    int res_l, res_r;  
    int l = 0, r = n-1, diff = INT_MAX;
    while (r > l)
    {
       if (abs(arr[l] + arr[r] - x) < diff)
       {
           res_l = l;
           res_r = r;
           diff = abs(arr[l] + arr[r] - x);
       }
       if (arr[l] + arr[r] > x)
           r--;
       else
           l++;
    }
    cout <<" The closest pair is " << arr[res_l] << " and " << arr[res_r];
}

int main()
{
    int arr[] =  {10, 22, 28, 29, 32, 40}, x = 54;
    int n = sizeof(arr)/sizeof(arr[0]);
    printClosest(arr, n, x);
    return 0;
}

See Running code at http://ideone.com/q3F4OQ

Similar Articles

Filed Under: Adobe Interview Questions, Amazon Interview Question, Flipkart Interview Questions, Interview Questions, problem Tagged With: Array

Reader Interactions

Primary Sidebar

Join WeekEnd Online/Offline Batch from 4-April-2020 on How to Crack Coding Interview in Just 10 Weeks : Fees just 20,000 INR

Join WeekEnd Online/Offline Batch from 4-April-2020

WhatsApp us

Secondary Sidebar

Custom Search

  • How I cracked AMAZON
  • LeetCode
  • Adobe
  • Amazon
  • Facebook
  • Microsoft
  • Hacker Earth
  • CSE Interview

Top Rated Questions

Subset Sum Problem Dynamic programming

Binary Tree in Java

Word Break Problem

Skiing on Mountains Matrix

VMWare Openings

Trie Dictionary

Check a String is SUBSEQUENCE of another String Find Minimum length for that ( DNA Matching )

Sequence Finder Dynamic Programming

Calculate price of parking from parking start end time prices

Common Ancestor in a Binary Tree or Binary Search Tree

Client Server C program

Given a string, find the first character which is non-repetitive

Find min element in Sorted Rotated Array (With Duplicates)

K’th Largest Element in BST when modification to BST is not allowed

Binary Tree in Java

Rectangular chocolate bar Create at least one piece which consists of exactly nTiles tiles

Find Nearest Minimum number in left side in O(n)

Given Set of words or A String find whether chain is possible from these words or not

Implement LRU Cache

Count number of ways to reach a given score in a game

C Program for TAIL command of UNIX

Find loop in Singly linked list

Level order traversal in Spiral form

Inorder and Preorder traversals of a Binary Tree given. Output the Postorder traversal of it.

Find shortest distances between every pair of vertices ( Dynamic Programming Floyd Warshall Algorithm)

Facebook Interview Question : Interleave List

Daughter’s Age VeryGood Puzzle

Serialise Deserialise N-ary Tree

Find and print longest consecutive number sequence in a given sequence in O(n)

Length of the longest substring without repeating characters

Copyright © 2026 · Genesis Framework · WordPress · Log in