You only have free questions left (including this one).

But it doesn't have to end here! Sign up for the 7-day coding interview crash course and you'll get a free Interview Cake problem every week.

Your company built an in-house calendar tool called HiCal. You want to add a feature to see the times in a day when everyone is available.

To do this, you’ll need to know when any team is having a meeting. In HiCal, a meeting is stored as an instance of a ICKMeeting class with unsigned integer properties startTime and endTime. These integers represent the number of 30-minute blocks past 9:00am.

@interface ICKMeeting : NSObject @property (nonatomic) NSUInteger startTime; @property (nonatomic) NSUInteger endTime; - (instancetype)initWithStartTime:(NSUInteger)startTime endTime:(NSUInteger)endTime; @end @implementation ICKMeeting - (instancetype)initWithStartTime:(NSUInteger)startTime endTime:(NSUInteger)endTime { if (self = [super init]) { // number of 30 min blocks past 9:00 am self.startTime = startTime; self.endTime = endTime; } return self; } @end

For example:

ICKMeeting *meeting1 = [[ICKMeeting alloc] initWithStartTime:2 endTime:3]; ICKMeeting *meeting2 = [[ICKMeeting alloc] initWithStartTime:6 endTime:9];

Write a function mergeRanges that takes an array of multiple meeting time ranges and returns an array of condensed ranges.

For example, given:

@[ [[ICKMeeting alloc] initWithStartTime:0 endTime:1], [[ICKMeeting alloc] initWithStartTime:3 endTime:5], [[ICKMeeting alloc] initWithStartTime:4 endTime:8], [[ICKMeeting alloc] initWithStartTime:10 endTime:12], [[ICKMeeting alloc] initWithStartTime:9 endTime:10] ]

your function would return:

@[ [[ICKMeeting alloc] initWithStartTime:0 endTime:1], [[ICKMeeting alloc] initWithStartTime:3 endTime:8], [[ICKMeeting alloc] initWithStartTime:9 endTime:12] ]

Do not assume the meetings are in order. The meeting times are coming from multiple teams.

Write a solution that's efficient even when we can't put a nice upper bound on the numbers representing our time ranges. Here we've simplified our times down to the number of 30-minute slots past 9:00 am. But we want the function to work even for very large numbers, like Unix timestamps. In any case, the spirit of the challenge is to merge meetings where startTime and endTime don't have an upper bound.

Look at this case:

@[ [[ICKMeeting alloc] initWithStartTime:1 endTime:2], [[ICKMeeting alloc] initWithStartTime:2 endTime:3] ]

These meetings should probably be merged, although they don't exactly "overlap"—they just "touch." Does your function do this?

Look at this case:

@[ [[ICKMeeting alloc] initWithStartTime:1 endTime:5], [[ICKMeeting alloc] initWithStartTime:2 endTime:3] ]

Notice that although the second meeting starts later, it ends before the first meeting ends. Does your function correctly handle the case where a later meeting is "subsumed by" an earlier meeting?

Look at this case:

@[ [[ICKMeeting alloc] initWithStartTime:1 endTime:10], [[ICKMeeting alloc] initWithStartTime:2 endTime:6], [[ICKMeeting alloc] initWithStartTime:3 endTime:5], [[ICKMeeting alloc] initWithStartTime:7 endTime:9] ]

Here all of our meetings should be merged together into just @[ [[ICKMeeting alloc] initWithStartTime:1 endTime:10] ]. We need keep in mind that after we've merged the first two we're not done with the result—the result of that merge may itself need to be merged into other meetings as well.

Make sure that your function won't "leave out" the last meeting.

We can do this in time.

Start your free trial!

Log in or sign up with one click to get immediate access to free mock interview questions

Where do I enter my password?

Actually, we don't support password-based login. Never have. Just the OAuth methods above. Why?

  1. It's easy and quick. No "reset password" flow. No password to forget.
  2. It lets us avoid storing passwords that hackers could access and use to try to log into our users' email or bank accounts.
  3. It makes it harder for one person to share a paid Interview Cake account with multiple people.

Start your free trial!

Log in or sign up with one click to get immediate access to free mock interview questions

Where do I enter my password?

Actually, we don't support password-based login. Never have. Just the OAuth methods above. Why?

  1. It's easy and quick. No "reset password" flow. No password to forget.
  2. It lets us avoid storing passwords that hackers could access and use to try to log into our users' email or bank accounts.
  3. It makes it harder for one person to share a paid Interview Cake account with multiple people.

time and space.

Even though we only walk through our array of meetings once to merge them, we sort all the meetings first, giving us a runtime of . It's worth noting that if our input were sorted, we could skip the sort and do this in time!

We create a new array of merged meeting times. In the worst case, none of the meetings overlap, giving us an array identical to the input array. Thus we have a worst-case space cost of .

  1. What if we did have an upper bound on the input values? Could we improve our runtime? Would it cost us memory?
  2. Could we do this "in place" on the input array and save some space? What are the pros and cons of doing this in place?

Start your free trial!

Log in or sign up with one click to get immediate access to free mock interview questions

Where do I enter my password?

Actually, we don't support password-based login. Never have. Just the OAuth methods above. Why?

  1. It's easy and quick. No "reset password" flow. No password to forget.
  2. It lets us avoid storing passwords that hackers could access and use to try to log into our users' email or bank accounts.
  3. It makes it harder for one person to share a paid Interview Cake account with multiple people.

Reset editor

Powered by qualified.io

. . .