47 practice questions for Stripe Mobile Engineer interviews
Stripe mobile engineer interviews focus on iOS or Android platform knowledge, memory management, offline-first architecture, and mobile-specific system design.
Category: Tree coding problemYou are building a role-based access control (RBAC) system for a multi-tenant platform. The system manages user roles across a hierarchical account...Input: List Output: Array
codingHardVerified Question#2
2. Rate Limiter
Category: Sliding window coding problemDesign a rate limiter that tracks API requests per client and enforces limits using a sliding time window. Your system must support: - hit(key,...Input: Given input Output:** Computed result
codingMediumVerified Question#3
3. Shipping Cost Calculator
Category: Algorithm coding problemYou are building a shipping cost calculator for an international e-commerce platform. The cost depends on the destination country and the product...Input: Integer(s) Output: Computed result
codingMediumVerified Question#4
4. Transaction Fee Calculator
Category: Trie-based coding problemYou are building a fee calculation system for a payment processing platform. Given transaction data as a CSV string, calculate fees based on payment...Input: String Output: Computed result
codingMediumVerified Question#5
5. Bitmap to Image Conversion
Category: Grid/matrix coding problemYou are designing a bitmap character rendering system. Given a lookup table mapping characters to 2D binary arrays, implement functionality to print,...Input: 2D grid Output: Printed output
codingMediumVerified Question#6
6. [Onsite Integration] Bike Map
Category: Trie-based coding problemYou are building a map visualization tool that generates static maps from location data. Implement a system that reads GPS coordinates, constructs...Input: Array Output: Computed result
codingHardVerified Question#7
7. Email Subscriptions
Category: String coding problemDesign a subscription management system that tracks user subscriptions and sends automated emails at specific lifecycle events. Email Types: -...Input: List Output: Computed result
codingHardVerified Question#8
8. [Bug Squash] Mako Template Engine
Category: Tree coding problemIn this bug squash round, you will find and fix errors in a Python template library. You will receive a link to a GitHub folder containing a version...Input: List Output: Printed output
codingHardVerified Question#9
9. [Bug Squash] Moshi JSON Library
Category: String coding problemIn this bug squash round, you will find and fix mistakes in a Java library called Moshi. You will receive a link to a GitHub folder containing a...Input: String Output: Computed result
codingHardVerified Question#10
10. Data Center Load Scorer
Category: Graph coding problemA data center operations team monitors server energy usage to optimize resource allocation. You receive a daily dataset of all incoming requests to...Input: Graph (nodes and edges) Output: Array
codingMediumVerified Question#11
11. Content Validation Pipeline
Category: String coding problemA platform ingests user-generated content records in a simplified CSV format. Before indexing or displaying any content, each record must pass a...Input: Array of strings Output: Array
codingHardVerified Question#12
12. Wallet Transaction Ledger
Category: String coding problemA fintech platform processes streams of wallet transactions and needs to consolidate them into account summaries. Each transaction is logged as a...Input: List Output: Computed result
codingHardVerified Question#13
13. Employee Record Matcher
Category: Array coding problemA data-quality team needs to detect duplicate or near-duplicate employee records in a large HR dataset. Each record is a row in a 2D string array...Input: Array Output: Array
codingHardVerified Question#14
14. Candidate Tech Stack Filter
Category: String coding problemA hiring platform screens candidates by comparing their declared technology stack against a job's required skills. A candidate submits a...Input: Array of strings Output: Array
codingHardVerified Question#15
15. Subscriber Notification Planner
Category: Trie-based coding problemA subscription service sends automated notifications to subscribers based on their subscription window. You are given a list of subscriber records...Input: List Output: Array
codingMediumVerified Question#16
16. Support Ticket Dispatcher
Category: Graph coding problemA customer support platform assigns incoming tickets to agents to keep workloads balanced. You are given a list of agent names and a list of tickets...Input: Graph (nodes and edges) Output: Array
codingMediumVerified Question#17
17. Order Payment Reconciler
Category: String coding problemA billing system needs to match incoming payments to open orders. Each payment arrives as a comma-separated string with three fields: a payment ID, a...Input: List Output: Computed result
codingMediumVerified Question#18
18. Service Usage Cost Calculator
Category: Array coding problemA cloud billing module computes the total cost for a customer's monthly usage. You are given a usage_report specifying the target region and...Input: Array Output: Computed result
codingHardgreedy#1
1. [OA] Greedy — Implement the optimal currency conversion system to minimize losses due to currency fluctuations while making payments
Stripe operates globally, dealing with multiple currencies, making effective currency conversion essential to minimize financial loss during conversions. Given a list of currency rates where each element represents the rate to convert from one currency to another, return the maximum amount you can convert from one currency to another using a greedy algorithm for optimal conversion. - Input:List<double> rates - Output:double — the maximum amount achievable after conversion.Example 1: Input: [0.74, 1.5, 0.6] Output: 1.11 Explanation: The best conversion path is from 0.74 to 1.5.Example 2: Input: [1.0, 0.9, 1.2] Output: 1.2 Explanation: No losses occur; simply pick the best rate.Constraints: - 1 <= rates.length <= 100 - 0 < rates[i] <= 10^2
codingHardsliding window#2
2. [OA] Sliding Window — Implement the feature to track the trends of failed payment attempts in a rolling window
In the context of Stripe's payment processing system, it’s crucial to understand which payment methods are failing consistently over time. This information can help in identifying issues and improving the payment experience. Given a list of integers representing the payment failures over the last n hours, implement a function that determines the maximum number of failures within any continuous window of k hours. - Input:List[int] failures, int k - Output:int — the maximum number of failures in any sliding window of size k.Example 1: Input: [1, 2, 1, 3, 2, 1], 3 Output: 5 Explanation: The sliding window [1, 3, 2] has a sum of 5 failures.Example 2: Input: [2, 3, 4, 5], 2 Output: 7 Explanation: The sliding window [3, 4] has a sum of 7 failures.Constraints: - 1 <= failures.length <= 10^5 - 1 <= failures[i] <= 10^4 - 1 <= k <= failures.length
system designSeniordistributed systems#3
3. [OA] Design an Offline-First Sync Engine to Manage Transactions in Stripe's Mobile App
Offline capabilities are essential for Stripe's mobile users, enabling transaction management without losing data when connectivity is limited. Design an Offline-First Sync Engine that ensures transactions are synchronized efficiently when online. You should implement a class OfflineSyncEngine with methods to add, sync, and retrieve transactions. - Method 1:addTransaction(Transaction tx) - adds a transaction locally. - Method 2:syncTransactions() - syncs all locally added transactions to the server when online. - Method 3:getTransactions() -> List<Transaction> - retrieves the list of transactions.Example 1: Input: addTransaction(new Transaction(...)) Output: None Input: syncTransactions() Output: None Input: getTransactions() Output: List<Transaction>Constraints: - The engine can handle up to 1000 transactions.
system designSeniorapi design#4
4. [OA] Tree — Design a Tree Structure to Represent Currency Exchange Rates
As part of Stripe’s financial services, representing fluctuating currency exchange rates in a tree structure can enable efficient querying and updates. This task involves creating an appropriate tree design to serve those needs. You are to implement a class CurrencyExchangeTree with methods to add rates, remove rates, and retrieve the rate between two currencies efficiently. - Method 1:addRate(String from, String to, double rate) - adds a new exchange rate. - Method 2:removeRate(String from, String to) - removes an exchange rate. - Method 3:getRate(String from, String to) -> double - Retrieves the exchange rate between two currencies.Example 1: Input: addRate('USD', 'EUR', 0.84) Output: None Input: getRate('USD', 'EUR') Output: 0.84Constraints: - The tree can have at most 100 unique currency nodes.