75. Sort Colors

Loading Question ...

Given an array with n objects colored red, white or blue, sort them so that objects of the same color are adjacent, with the colors in the order red, white and blue.

Here, we will use the integers 0, 1, and 2 to represent the color red, white, and blue respectively.

Note:
You are not suppose to use the library's sort function for this problem.

click to show follow up.

Follow up:
A rather straight forward solution is a two-pass algorithm using counting sort.
First, iterate the array counting number of 0's, 1's, and 2's, then overwrite array with total number of 0's, then 1's and followed by 2's.

Could you come up with an one-pass algorithm using only constant space?


Seen this question in a real interview before?  
Yes
No
When did you encounter this question?  
last week
last month
last 3 month
last 6 month
more than 6 months
other
Which company?  
Adobe
Aetion
Affirm
Airbnb
Alation
Alibaba
Amazon
AppDynamics
Apple
Arista
Baidu
Bank of America
BlackRock
Blend Labs
Blizzard
Bloomberg
Booking
Box
Bungie
Capital One
CareerBuilder
Cisco
Citadel
Coinbase
Concur
Conviva
Coupang
Coursera
CreditEase
CVTE
Dell
Deutsche Bank
DoorDash
Dropbox
Duolingo
EasyNet
eBay
Electronic Arts
EMC
Epic Systems
Equinix
Evernote
Expedia
Facebook
FactSet
Fitbit
Flipkart
Fortinet
FourSquare
FreeWheel
GoDaddy
Goldman Sachs
Google
GrabTaxi
Groupon
HBO
Hedvig
HomeAway
HTC
Huawei
Hulu
IBG
IBM
Indeed
InnovatureLabs
Intel
IXL
Jane Street
JPMorgan
Jump Trading
Lending Club
LinkedIn
LiveRamp
Loovee
Marvel
Matlab
McKesson
Microsoft
Morgan Stanley
NetEase
Nintendo
Nutanix
Nvidia
Oracle
Orbitz
Palantir
Paypal
Pinterest
Pocket Gems
Point72
Qualcomm
Qualtrics
Qumulo
Quora
Rackspace
Redfin
Rubrik
Salesforce
Samsung
SAP
ServiceNow
Sina
Snapchat
SoftwareOne
Sony
SoundHound
Square
Sumologic
SurveyMonkey
Symantec
Tableau
Tencent
Tesorio
TinyCo
Tradeshift
TripAdvisor
Twilio
Twitter
Two Sigma
Uber
Veritas
Visa
VMware
Walmart
Wealthfront
Whitepages
Works Applications
Yahoo
Yandex
Yelp
Zappos
Zenefits
Zillow
Zynga