Track animal migrations across different locations. Given a list of animal movements (animal ID, from location, to location, date), return a map of animals and their complete migration paths sorted by date. Skip invalid movements where the 'from' location doesn't match the animal's last known location.

Examples:

Input: movements = [
    {'A1', 'Forest', 'Lake', '2024-01-01'},
    {'A1', 'Lake', 'Mountain', '2024-01-02'},
    {'A2', 'Desert', 'Forest', '2024-01-01'},
    {'A1', 'River', 'Valley', '2024-01-03'}
]
Output: {
    'A1': ['Forest -> Lake', 'Lake -> Mountain'],
    'A2': ['Desert -> Forest']
}
Explanation: A1's third movement is invalid (from River when last known location was Mountain), A2 has one valid movement

Input: movements = [
    {'B1', 'Cave', 'Forest', '2024-02-01'},
    {'B1', 'Forest', 'Lake', '2024-02-02'}
]
Output: {
    'B1': ['Cave -> Forest', 'Forest -> Lake']
}
Explanation: All movements are valid as each 'from' location matches the previous 'to' location

Apex Code Editor

Welcome to Lightning Challenge!

Create an Account

Sign up to track your progress, earn points, and compete with others. Your solutions will be saved automatically.

Create account

How It Works

  • • Write your solution in the code editor
  • • Connect your Salesforce org to test
  • • Submit to check if your solution passes
  • • Use hints if you get stuck

Note

🏆 MVP Contest 2: The #1 ranked player on our global leaderboard by February 28th will receive a free Salesforce $200 certification voucher! Contest runs Feb 15-28. Track your position and compete for the prize! Points are only calculated for questions created and completed during the contest period.