Stripe logo

Stripe Mobile Engineer Interview Questions

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.

All Roles Software Engineer Backend Engineer Frontend Engineer Full Stack Engineer Mobile Engineer Data Engineer Data Scientist ML Engineer DevOps Engineer DevOps Engineer Product Manager SRE Security Engineer Engineering Manager Data Analyst UX/UI Designer QA Engineer
coding Hard Verified Question #1

1. Filter Roles


Category: Tree coding problem
You 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
coding Hard Verified Question #2

2. Rate Limiter


Category: Sliding window coding problem
Design 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
coding Medium Verified Question #3

3. Shipping Cost Calculator


Category: Algorithm coding problem
You 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
coding Medium Verified Question #4

4. Transaction Fee Calculator


Category: Trie-based coding problem
You 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
coding Medium Verified Question #5

5. Bitmap to Image Conversion


Category: Grid/matrix coding problem
You 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
coding Medium Verified Question #6

6. [Onsite Integration] Bike Map


Category: Trie-based coding problem
You 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
coding Hard Verified Question #7

7. Email Subscriptions


Category: String coding problem
Design a subscription management system that tracks user subscriptions and sends automated emails at specific lifecycle events. Email Types: -...
Input: List
Output: Computed result
coding Hard Verified Question #8

8. [Bug Squash] Mako Template Engine


Category: Tree coding problem
In 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
coding Hard Verified Question #9

9. [Bug Squash] Moshi JSON Library


Category: String coding problem
In 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
coding Hard Verified Question #10

10. Data Center Load Scorer


Category: Graph coding problem
A 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
coding Medium Verified Question #11

11. Content Validation Pipeline


Category: String coding problem
A 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
coding Hard Verified Question #12

12. Wallet Transaction Ledger


Category: String coding problem
A 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
coding Hard Verified Question #13

13. Employee Record Matcher


Category: Array coding problem
A 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
coding Hard Verified Question #14

14. Candidate Tech Stack Filter


Category: String coding problem
A 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
coding Hard Verified Question #15

15. Subscriber Notification Planner


Category: Trie-based coding problem
A subscription service sends automated notifications to subscribers based on their subscription window. You are given a list of subscriber records...
Input: List
Output: Array
coding Medium Verified Question #16

16. Support Ticket Dispatcher


Category: Graph coding problem
A 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
coding Medium Verified Question #17

17. Order Payment Reconciler


Category: String coding problem
A 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
coding Medium Verified Question #18

18. Service Usage Cost Calculator


Category: Array coding problem
A 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
coding Hard greedy #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
coding Hard sliding 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 design Senior distributed 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 design Senior api 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.84
Constraints:
- The tree can have at most 100 unique currency nodes.

Related Stripe Mobile Engineer interview prep

Start practicing Stripe questions

Sign up for free to access walkthroughs, AI-generated questions, and more.

Get Started Free