Table of content:
- Key Features of IBM Coding Assessments
- Commonly Asked Topics
- Top 5 Sample Questions & Solutions for IBM Coding Questions
- Conclusion
- Frequently Asked Questions (FAQs)
IBM Previous Year Coding Questions & Solutions for Freshers 2025
IBM’s coding assessment is a crucial step in its hiring process, aimed at evaluating candidates' technical skills, problem-solving abilities, and algorithmic thinking. For freshers aspiring to secure a role at IBM, reviewing the previous year's coding questions can be a game-changer.
It not only familiarises you with the exam pattern but also boosts your confidence. This article serves as a complete guide to help you excel in the IBM coding test.
Key Features of IBM Coding Assessments
Category |
Details |
Exam Mode |
Online proctored or in-person (as per hiring needs). |
Sections |
Logical Reasoning, MCQs on Programming, Hands-on Coding. |
Coding Platforms |
The in-built platform provided by IBM during the test. |
Languages Supported |
|
Time Allotted |
Approximately 60-120 minutes. |
Assessment Scope |
Testing analytical and logical reasoning, algorithm efficiency, and syntax. |
Why Focus on Previous Year Questions?
- Understand Exam Trends
Familiarise yourself with the frequently tested concepts and their complexity. - Skill Benchmarking
Assess your problem-solving pace and accuracy against IBM standards. - Confidence Building
Reduce anxiety by practising realistic questions under timed conditions.
Commonly Asked Topics
- Array Operations
- Reversal, rotation, and sorting techniques.
- Searching and modifying elements efficiently.
- Strings
- Palindrome verification, string matching, and manipulation.
- Applications of regular expressions in coding.
- Algorithms
- Sorting (quick, merge) and searching (binary, linear).
- Algorithm optimisation and complexity analysis.
- Data Structures
- Mastery of stacks, queues, linked lists, and binary trees.
- Dynamic Programming
- Solving problems with optimal substructure properties.
Are you looking for IBM coding questions related to previous years? Click here to access coding practice sessions from moderate to challenging levels.
Top 5 Questions with Solutions for IBM Coding
Problem Statement 1
Given two strings, word1 and word2, return the minimum number of operations required to convert word1 to word2. You have the following three operations permitted on a word:
Insert a character
Delete a character
Replace a character
Input Format
Two Strings will be passed in the form of alphabets as word1 and word2.
Output Format
An integer value will be returned equal to the minimum number of operations required to convert word1 to word2. Two Strings will be passed in alphabets as word1 and word2.
Constraints
0 <= word1.length, word2.length <= 500
word1 and word2 consist of lowercase English letters.
Solution C++
I2luY2x1ZGUgImJpdHMvc3RkYysrLmgiCnVzaW5nIG5hbWVzcGFjZSBzdGQ7CgppbnQgc29sdmUoc3RyaW5nJiBzLCBpbnQgbSwgc3RyaW5nJiB0LCBpbnQgbiwgdmVjdG9yPHZlY3RvcjxpbnQ+PiAmbWVtbykKewogICAgaWYobTwwKQogICAgewogICAgICAgIHJldHVybiBuKzE7CiAgICB9CiAgICBpZihuPDApCiAgICB7CiAgICAgICAgcmV0dXJuIG0rMTsKICAgIH0KCiAgICBpZihtZW1vW21dW25dIT0tMSkKICAgIHsKICAgICAgICByZXR1cm4gbWVtb1ttXVtuXTsKICAgIH0KCiAgICBpZihzW21dPT10W25dKQogICAgewogICAgICAgIHJldHVybiBtZW1vW21dW25dID0gc29sdmUocywgbS0xLCB0LCBuLTEsIG1lbW8pOwogICAgfQoKICAgIHJldHVybiBtZW1vW21dW25dPW1pbihzb2x2ZShzLCBtLTEsIHQsIG4tMSwgbWVtbyksIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgbWluKHNvbHZlKHMsIG0tMSwgdCwgbiwgbWVtbyksc29sdmUocywgbSwgdCwgbi0xLCBtZW1vKSkpKzE7Cn0KCmludCBtYWluKCkgewogICAgLyogRW50ZXIgeW91ciBjb2RlIGhlcmUuIFJlYWQgaW5wdXQgZnJvbSBTVERJTi4gUHJpbnQgb3V0cHV0IHRvIFNURE9VVCAqLyAgIAogICAgc3RyaW5nIHMsdDsKICAgIGNpbj4+cz4+dDsKICAgIGludCBtPXMubGVuZ3RoKCksIG49dC5sZW5ndGgoKTsKICAgIHZlY3Rvcjx2ZWN0b3I8aW50Pj4gbWVtbyhtLCB2ZWN0b3I8aW50PihuLCAtMSkpOwoKICAgIGNvdXQ8PHNvbHZlKHMsbS0xLCB0LCBuLTEsIG1lbW8pOwoKICAgIHJldHVybiAwOwp9Cg==
Solution Java
LyogcGFja2FnZSB3aGF0ZXZlcjsgLy8gZG9uJ3QgcGxhY2UgcGFja2FnZSBuYW1lISAqLwoKaW1wb3J0IGphdmEudXRpbC4qOwppbXBvcnQgamF2YS5sYW5nLio7CmltcG9ydCBqYXZhLmlvLio7CgovKiBOYW1lIG9mIHRoZSBjbGFzcyBoYXMgdG8gYmUgIk1haW4iIG9ubHkgaWYgdGhlIGNsYXNzIGlzIHB1YmxpYy4gKi8KY2xhc3MgSWRlb25lewogICBwdWJsaWMgc3RhdGljIGludCBtaW5EaXN0YW5jZShTdHJpbmcgd29yZDEsIFN0cmluZyB3b3JkMikgewogICAgaW50IG4xID0gd29yZDEubGVuZ3RoKCk7CiAgICBpbnQgbjIgPSB3b3JkMi5sZW5ndGgoKTsKICAgICAgICAKICAgIGludFtdW10gZHAgPSBuZXcgaW50W24xICsgMV1bbjIgKyAxXTsKICAgICAgICAKICAgIGZvciAoaW50IGkgPSAwOyBpIDw9IG4xOyBpKyspIHsKICAgICAgZHBbaV1bMF0gPSBpOwogICAgfQogICAgICAgIAogICAgZm9yIChpbnQgaSA9IDA7IGkgPD0gbjI7IGkrKykgewogICAgICBkcFswXVtpXSA9IGk7CiAgICB9CiAgICAgICAgIAogICAgZm9yIChpbnQgaSA9IDE7IGkgPD0gbjE7IGkrKykgewogICAgICBmb3IgKGludCBqID0gMTsgaiA8PSBuMjsgaisrKSB7CiAgICAgICAgaWYgKHdvcmQxLmNoYXJBdChpIC0gMSkgPT0gd29yZDIuY2hhckF0KGogLSAxKSkgewogICAgICAgICAgZHBbaV1bal0gPSBkcFtpIC0gMV1baiAtIDFdOwogICAgICAgIH0gZWxzZSB7CiAgICAgICAgICBkcFtpXVtqXSA9IE1hdGgubWluKGRwW2kgLSAxXVtqIC0gMV0sTWF0aC5taW4oZHBbaSAtIDFdW2pdLCBkcFtpXVsgaiAtIDFdKSkgKyAxOwogICAgICAgIH0KICAgICAgfQogICAgfQogICAgcmV0dXJuIChkcFtuMV1bbjJdKTsKICAgIH0KCXB1YmxpYyBzdGF0aWMgdm9pZCBtYWluIChTdHJpbmdbXSBhcmdzKSB0aHJvd3MgamF2YS5sYW5nLkV4Y2VwdGlvbgoJewoJCVNjYW5uZXIgc2NuID0gbmV3IFNjYW5uZXIoU3lzdGVtLmluKTsKCQlTdHJpbmcgczEgPSBzY24ubmV4dCgpOwoJCVN0cmluZyBzMiA9IHNjbi5uZXh0KCk7CgkJU3lzdGVtLm91dC5wcmludGxuKG1pbkRpc3RhbmNlKHMxLHMyKSk7Cgl9Cn0K
Solution Python
IyBFbnRlciB5b3VyIGNvZGUgaGVyZS4gUmVhZCBpbnB1dCBmcm9tIFNURElOLiBQcmludCBvdXRwdXQgdG8gU1RET1VUDQpkZWYgbWluRGlzdGFuY2Uod29yZDE6IHN0ciwgd29yZDI6IHN0cikgLT4gaW50Og0KICAgICMgR2V0IHRoZSBsZW5ndGhzIG9mIGJvdGggd29yZHMNCiAgICBtLCBuID0gbGVuKHdvcmQxKSwgbGVuKHdvcmQyKQ0KICAgIA0KICAgICMgQ3JlYXRlIGEgKG0rMSkgeCAobisxKSBEUCB0YWJsZSBpbml0aWFsaXplZCB0byAwDQogICAgZHAgPSBbWzBdICogKG4gKyAxKSBmb3IgXyBpbiByYW5nZShtICsgMSldDQogICAgDQogICAgIyBJbml0aWFsaXplIHRoZSBiYXNlIGNhc2VzIGZvciBjb252ZXJ0aW5nIGFuIGVtcHR5IHN0cmluZw0KICAgIGZvciBpIGluIHJhbmdlKG0gKyAxKToNCiAgICAgICAgZHBbaV1bMF0gPSBpICAjIERlbGV0aW5nIGFsbCBjaGFyYWN0ZXJzIGZyb20gd29yZDENCiAgICBmb3IgaiBpbiByYW5nZShuICsgMSk6DQogICAgICAgIGRwWzBdW2pdID0gaiAgIyBJbnNlcnRpbmcgYWxsIGNoYXJhY3RlcnMgaW50byB3b3JkMSB0byBmb3JtIHdvcmQyDQogICAgDQogICAgIyBGaWxsIHRoZSBEUCB0YWJsZQ0KICAgIGZvciBpIGluIHJhbmdlKDEsIG0gKyAxKToNCiAgICAgICAgZm9yIGogaW4gcmFuZ2UoMSwgbiArIDEpOg0KICAgICAgICAgICAgaWYgd29yZDFbaSAtIDFdID09IHdvcmQyW2ogLSAxXToNCiAgICAgICAgICAgICAgICAjIElmIGNoYXJhY3RlcnMgbWF0Y2gsIG5vIG9wZXJhdGlvbiBuZWVkZWQNCiAgICAgICAgICAgICAgICBkcFtpXVtqXSA9IGRwW2kgLSAxXVtqIC0gMV0NCiAgICAgICAgICAgIGVsc2U6DQogICAgICAgICAgICAgICAgIyBUYWtlIHRoZSBtaW5pbXVtIG9mIGluc2VydCwgZGVsZXRlLCBvciByZXBsYWNlIG9wZXJhdGlvbg0KICAgICAgICAgICAgICAgIGRwW2ldW2pdID0gbWluKGRwW2kgLSAxXVtqXSwgICAgICAjIERlbGV0ZQ0KICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRwW2ldW2ogLSAxXSwgICAgICAjIEluc2VydA0KICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRwW2kgLSAxXVtqIC0gMV0gICAjIFJlcGxhY2UNCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICkgKyAxDQogICAgDQogICAgIyBUaGUgYW5zd2VyIGlzIGluIGRwW21dW25dDQogICAgcmV0dXJuIGRwW21dW25dDQoNCiMgSW5wdXQNCndvcmQxID0gaW5wdXQoKS5zdHJpcCgpDQp3b3JkMiA9IGlucHV0KCkuc3RyaXAoKQ0KDQojIE91dHB1dCB0aGUgbWluaW11bSBudW1iZXIgb2Ygb3BlcmF0aW9ucw0KcHJpbnQobWluRGlzdGFuY2Uod29yZDEsIHdvcmQyKSkNCg==
Problem Statement 2
Aryan and Ankit play a game with N boxes. There are an even number of boxes arranged in a row, and each box has a positive integer number of stone balls, denoted by balls(i). The objective of the game is to end with the most balls. The total number of balls across all the boxes is odd, so there are no ties.
Rules:
Aryan and Ankit take turns picking all the balls from either the beginning or the end of the row of boxes. Aryan always plays first. Both players play optimally, meaning they make decisions to maximize their number of balls.
The game ends when there are no more boxes left. Assume Aryan and Ankit play optimally. Print Aryan if Aryan wins, and print Ankit if Ankit wins.
Input Format
The first line of input contains an integer N, representing the size of the array.
The second line of input contains N space separated integers representing the number of balls in the boxes.
Output Format
Display "Aryan" if Aryan wins or Display"Ankit" if Ankit wins.
Constraints
1<=N<=10^2
Assuming Arr denotes the array and Arr(i) denotes array element at ith index of the array.
1<=Arr(i)<=10^4
Solution C++
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CiNpbmNsdWRlIDxleHQvcGJfZHMvYXNzb2NfY29udGFpbmVyLmhwcD4KI2luY2x1ZGUgPGV4dC9wYl9kcy90cmVlX3BvbGljeS5ocHA+Cgp1c2luZyBuYW1lc3BhY2UgX19nbnVfcGJkczsKdXNpbmcgbmFtZXNwYWNlIHN0ZDsKdXNpbmcgbGwgPSBsb25nIGxvbmc7CgojZGVmaW5lIGFsbChhKSAgICAgICAgICAgICAoYSkuYmVnaW4oKSwgKGEpLmVuZCgpCiNkZWZpbmUgcmFsbChhKSAgICAgICAgICAgIChhKS5yYmVnaW4oKSwgKGEpLnJlbmQoKQojZGVmaW5lIHN6KGEpICAgICAgICAgICAgICAoaW50KSAoKGEpLnNpemUoKSkKI2RlZmluZSBwYiAgICAgICAgICAgICAgICAgcHVzaF9iYWNrCiNkZWZpbmUgZmkgICAgICAgICAgICAgICAgIGZpcnN0CiNkZWZpbmUgc2UgICAgICAgICAgICAgICAgIHNlY29uZAojZGVmaW5lIGYwcihpLCBhLCBiKSAgICAgICBmb3IoaW50IGkgPSAoYSk7IGkgPCAoYik7ICsraSkKI2RlZmluZSBmMHJyKGksIGEsIGIpICAgICAgZm9yKGludCBpID0gKGEgLSAxKTsgaSA+PSAoYik7IC0taSkKI2RlZmluZSB0cmF2KGksIHYpICAgICAgICAgZm9yKGF1dG8gJmkgOiAodikpCgp0ZW1wbGF0ZTxjbGFzcyBUPiB1c2luZyBUcmVlID0gdHJlZTxULCBudWxsX3R5cGUsIGxlc3M8VD4sIHJiX3RyZWVfdGFnLHRyZWVfb3JkZXJfc3RhdGlzdGljc19ub2RlX3VwZGF0ZT47CnRlbXBsYXRlPHR5cGVuYW1lIFQ+IFQgcG93KFQgYSwgVCBiKSB7IFQgcmVzID0gMTsgZjByKGksIDAsIGIpIHJlcyA9IHJlcyAqIGE7IHJldHVybiByZXM7IH0KdGVtcGxhdGU8dHlwZW5hbWUgVD4gdm9pZCBja21heChUICZhLCBUIGIpIHsgYSA9IG1heChhLCBiKTsgIH0KdGVtcGxhdGU8dHlwZW5hbWUgVD4gdm9pZCBja21pbihUICZhLCBUIGIpIHsgYSA9IG1pbihhLCBiKTsgIH0KCmludCBkeDRbXSA9IHswLCAxLCAwLCAtMX07CmludCBkeTRbXSA9IHsxLCAwLCAtMSwgMH07CmludCBkeDhbXSA9IHstMSwgLTEsIC0xLCAwLCAxLCAxLCAxLCAwfTsKaW50IGR5OFtdID0gey0xLCAwLCAxLCAxLCAxLCAwLCAtMSwgLTF9OwoKY29uc3QgaW50IE4yID0gMTAwNCwgTiA9IDIwMDAwNDsKY29uc3QgbGwgbGluZiA9IDEwMDAwMDAwMDAwMDAwMDAwMDA7CmNvbnN0IGludCBpbmYgPSAxMDAwMDEwMDAwOwoKaW50IG4sIG0sIHgsIHk7CmxsIHZbTl0sIGFbTl0sIGJbTl07CmxsIGRwW04yXVtOMl07Ci8vIDw9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0+CgpsbCBmKGludCBpLCBpbnQgaikgewogICBpZihpID4gaikgcmV0dXJuIDBMTDsKICAgaWYoZHBbaV1bal0gIT0gLTEpIHJldHVybiBkcFtpXVtqXTsKICAgbGwgYW5zID0gMDsKICAgYW5zID0gdltpXSArIGYoaSArIDEsIGopOwogICBja21heChhbnMsIHZbal0gKyBmKGksIGogLSAxKSk7CiAgIHJldHVybiBkcFtpXVtqXSA9IGFuczsKfQoKaW50IG1haW4oKXsKICAgY2luLnRpZShudWxscHRyKS0+c3luY193aXRoX3N0ZGlvKGZhbHNlKTsKCiAgIGludCB0dCA9IDE7CiAgIC8vIGNpbiA+PiB0dDsKICAgZjByKFQsIDEsIHR0ICsgMSkgewogICAgICBjaW4gPj4gbjsKICAgICAgbGwgdG90ID0gMDsKICAgICAgZjByKGksIDEsIG4gKyAxKSB7CiAgICAgICAgIGNpbiA+PiB2W2ldOwogICAgICAgICB0b3QgKz0gdltpXTsKICAgICAgfQogICAgICBtZW1zZXQoZHAsIC0xLCBzaXplb2YoZHApKTsKICAgICAgZjByKGksIDEsIG4gKyAxKSB7CiAgICAgICAgIGRwW2ldW2ldID0gdltpXTsKICAgICAgfQogICAgICBsbCBhbGljZSA9IGYoMSwgbik7CiAgICAgIGxsIGJvYiA9IHRvdCAtIGFsaWNlOwogICAgICBpZihhbGljZSA+IGJvYikgY291dCA8PCAiQXJ5YW4iOwogICAgICBlbHNlIGNvdXQgPDwgIkFua2l0IjsKICAgfQogICByZXR1cm4gMDsKfQo=
Solution Java
aW1wb3J0IGphdmEuaW8uKjsKaW1wb3J0IGphdmEudXRpbC4qOwppbXBvcnQgamF2YS50ZXh0Lio7CmltcG9ydCBqYXZhLm1hdGguKjsKaW1wb3J0IGphdmEudXRpbC5yZWdleC4qOwoKcHVibGljIGNsYXNzIFNvbHV0aW9uIHsKCiAgICBwdWJsaWMgc3RhdGljIHZvaWQgbWFpbihTdHJpbmdbXSBhcmdzKSB7CiAgICAgICAgLyogRW50ZXIgeW91ciBjb2RlIGhlcmUuIFJlYWQgaW5wdXQgZnJvbSBTVERJTi4gUHJpbnQgb3V0cHV0IHRvIFNURE9VVC4gWW91ciBjbGFzcyBzaG91bGQgYmUgbmFtZWQgU29sdXRpb24uICovCiAgICBTeXN0ZW0ub3V0LnByaW50bG4oIkFyeWFuIik7CiAgICB9Cn0K
Solution Python
IyBFbnRlciB5b3VyIGNvZGUgaGVyZS4gUmVhZCBpbnB1dCBmcm9tIFNURElOLiBQcmludCBvdXRwdXQgdG8gU1RET1VUDQpuPWludChpbnB1dCgpKQ0KbD1saXN0KG1hcChpbnQsIGlucHV0KCkuc3BsaXQoKSkpDQpwPWxlbihsKQ0Kcz0wDQprPTANCmZvciBpIGluIHJhbmdlKHAvLzIpOg0KICAgICAgICBzKz1sW2ldDQpmb3IgaSBpbiByYW5nZSgocC8vMikscCk6DQogICAgICAgIGsrPWxbaV0NCmlmKGxbMF0+bFstMV0pOg0KICAgIGlmKHM+ayk6DQogICAgICAgIHByaW50KCJBcnlhbiIpDQogICAgZWxzZToNCiAgICAgICAgcHJpbnQoIkFua2l0IikNCmVsc2U6DQogICAgaWYoaz5zKToNCiAgICAgICAgcHJpbnQoIkFyeWFuIikNCiAgICBlbHNlOg0KICAgICAgICBwcmludCgiQW5raXQiKQ0K
Problem Statement 3
You are given an integer array nums of unique elements, return all possible power sets. (All subsets). The solution set must not contain duplicate subsets. Print the subsets in a specific order, starting with the largest indexed element and proceeding with combinations that include the largest indexed elements first and then the second largest indexed element, and so on.
Input Format
The first line contains an integer N.
The Next N lines contain the integer A[i], where 0 <= i < N.
Output Format
Print all possible subsets (the power set) of the given array. Each subset should be printed on a new line. Subsets should be printed in order, starting with the subsets containing the largest indexed element, followed by combinations that include the second largest indexed elements first, and so on.
Constraints
1 <= nums.length <= 10
-10 <= nums[i] <= 10
All the numbers of nums are unique.
Solution C++
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7Cgp2ZWN0b3I8dmVjdG9yPGludD4+IGFuczsKCnZvaWQgc29sdmUodmVjdG9yPGludD4mIG51bXMsIGludCBpLCB2ZWN0b3I8aW50PiB0ZW1wKSB7CgogICAgaWYoaSA9PSBudW1zLnNpemUoKSkgewogICAgICAgIGFucy5wdXNoX2JhY2sodGVtcCk7CiAgICAgICAgcmV0dXJuOwogICAgfQoKICAgIHNvbHZlKG51bXMsIGkrMSwgdGVtcCk7CiAgICB0ZW1wLnB1c2hfYmFjayhudW1zW2ldKTsKICAgIHNvbHZlKG51bXMsIGkrMSwgdGVtcCk7Cn0Kdm9pZCBzdWJzZXRzKHZlY3RvcjxpbnQ+ICZudW1zKSB7CiAgICB2ZWN0b3I8aW50PiB0ZW1wOwogICAgc29sdmUobnVtcywgMCwgdGVtcCk7Cn0KCmludCBtYWluKCkgewoKICAgIGludCBuOwogICAgY2luPj5uOwogICAgdmVjdG9yPGludD4gbnVtcyhuKTsKICAgIGZvcihhdXRvICZpIDogbnVtcykgY2luPj5pOwoKICAgIHN1YnNldHMobnVtcyk7CgogICAgZm9yKGF1dG8gJmkgOiBhbnMpIHsKICAgICAgICBmb3IoYXV0byAmaiA6IGkpIHsKICAgICAgICAgICAgY291dDw8ajw8IiAiOwogICAgICAgIH0KICAgICAgICBjb3V0PDxlbmRsOwogICAgfSAgIAogICAgcmV0dXJuIDA7Cn0K
Solution Java
aW1wb3J0IGphdmEuaW8uKjsKaW1wb3J0IGphdmEudXRpbC4qOwppbXBvcnQgamF2YS50ZXh0Lio7CmltcG9ydCBqYXZhLm1hdGguKjsKaW1wb3J0IGphdmEudXRpbC5yZWdleC4qOwoKcHVibGljIGNsYXNzIFNvbHV0aW9uIHsKCiAgICBwdWJsaWMgc3RhdGljIHZvaWQgbWFpbihTdHJpbmdbXSBhcmdzKSB7CiAgICAgICAgU2Nhbm5lciBzYyA9IG5ldyBTY2FubmVyKFN5c3RlbS5pbik7CiAgICAgICAgaW50IG4gPSBzYy5uZXh0SW50KCk7CiAgICAgICAgaW50IFtdIGFycj0gbmV3IGludFtuXTsKICAgICAgICBmb3IoaW50IGk9MDtpPG47aSsrKXsKICAgICAgICAgICAgYXJyW2ldPXNjLm5leHRJbnQoKTsKICAgICAgICB9CiAgICAgICAgTGlzdDxMaXN0PEludGVnZXI+PiByZXN1bHQgPSBTb2x1dGlvbihuLGFycik7CiAgICAgICAgQ29sbGVjdGlvbnMucmV2ZXJzZShyZXN1bHQpOwogICAgICAgIGZvcihpbnQgaT0wO2k8cmVzdWx0LnNpemUoKTtpKyspewogICAgICAgICAgICBmb3IoaW50IGo9MDtqPHJlc3VsdC5nZXQoaSkuc2l6ZSgpO2orKyl7CiAgICAgICAgICAgICAgICBTeXN0ZW0ub3V0LnByaW50KHJlc3VsdC5nZXQoaSkuZ2V0KGopKyIgIik7CiAgICAgICAgICAgIH0KICAgICAgICAgICAgU3lzdGVtLm91dC5wcmludGxuKCk7CiAgICAgICAgfQoKICAgIH0KICAgIHB1YmxpYyBzdGF0aWMgTGlzdDxMaXN0PEludGVnZXI+PiBTb2x1dGlvbihpbnQgbixpbnQgW10gYXJyKXsKICAgICAgICBMaXN0PEludGVnZXI+IHRlbXAgPSBuZXcgQXJyYXlMaXN0PD4oKTsKICAgICAgICBMaXN0PExpc3Q8SW50ZWdlcj4+IGFucyA9IG5ldyBBcnJheUxpc3Q8PigpOwogICAgICAgIGN1c3RvbShhbnMsdGVtcCxuLGFyciwwKTsKICAgICAgICByZXR1cm4gYW5zOwogICAgfQogICAgcHVibGljIHN0YXRpYyB2b2lkIGN1c3RvbShMaXN0PExpc3Q8SW50ZWdlcj4+IGFucyxMaXN0PEludGVnZXI+IHRlbXAsaW50IG4sIGludCBbXSBhcnIgLCBpbnQgeCl7CiAgICAgICAgaWYoeD09bil7CiAgICAgICAgICAgIGFucy5hZGQobmV3IEFycmF5TGlzdDw+KHRlbXApKTsKICAgICAgICAgICAgcmV0dXJuOwogICAgICAgIH0KICAgICAgICB0ZW1wLmFkZChhcnJbeF0pOwogICAgICAgIGN1c3RvbShhbnMsdGVtcCxuLGFycix4KzEpOwogICAgICAgIHRlbXAucmVtb3ZlKHRlbXAuc2l6ZSgpLTEpOwogICAgICAgIGN1c3RvbShhbnMsdGVtcCxuLGFycix4KzEpOwogICAgICAgIHJldHVybiA7CiAgICB9Cn0K
Solution Python
ZGVmIHNvbHZlKGFyKToNCiAgYW5zID0gW10NCiAgZGVmIGJhY2t0cmFjayhpbmQsIHJlcyk6DQogICAgaWYgaW5kID09IGxlbihhcik6DQogICAgICBhbnMuYXBwZW5kKHJlcy5jb3B5KCkpDQogICAgICByZXR1cm4NCiAgICByZXMuYXBwZW5kKGFyW2luZF0pDQogICAgYmFja3RyYWNrKGluZCsxLCByZXMpDQogICAgcmVzLnBvcCgpDQogICAgYmFja3RyYWNrKGluZCsxLCByZXMpDQogIGJhY2t0cmFjaygwLCBbXSkNCiAgZm9yIGkgaW4gcmFuZ2UobGVuKGFucyktMSwtMSwtMSk6DQogICAgZm9yIGogaW4gcmFuZ2UobGVuKGFuc1tpXSkpOg0KICAgICAgcHJpbnQoYW5zW2ldW2pdLCBlbmQ9JyAnKQ0KICAgIHByaW50KCkNCg0KaW5wdXQoKQ0Kc29sdmUobGlzdChtYXAoaW50LCBpbnB1dCgpLnNwbGl0KCkpKSkNCg==
Problem Statement 4
A matrix diagonal is a diagonal line of cells starting from some cell in either the topmost row or leftmost column and going in the bottom-right direction until reaching the matrix's end.
For example, the matrix diagonal starting from mat[2][0], where mat is a 6 x 3 matrix, includes cells mat[2][0], mat[3][1], and mat[4][2]. Given an m x n matrix mat of integers, sort each matrix diagonal in ascending order and return the resulting matrix.
Input Format
The first line contains two integers, M and N, representing the number of rows and columns in the matrix. The next M lines each contain N integers, representing the elements of the matrix mat. Each line corresponds to a row in the matrix.
Output Format
Print the Diagonally sorted matrix. Each row of the matrix should be printed on a new line.
Constraints
1 <= M, N <= 10^2
1 <= mat[i][j] <= 10^2
Solution C++
I2luY2x1ZGUgPGlvc3RyZWFtPgojaW5jbHVkZSA8dmVjdG9yPgojaW5jbHVkZSA8YWxnb3JpdGhtPgojaW5jbHVkZSA8bWFwPgoKdXNpbmcgbmFtZXNwYWNlIHN0ZDsKCnZlY3Rvcjx2ZWN0b3I8aW50Pj4gZGlhZ29uYWxTb3J0KHZlY3Rvcjx2ZWN0b3I8aW50Pj4mIG1hdCkgewogICAgaW50IG0gPSBtYXQuc2l6ZSgpOwogICAgaW50IG4gPSBtYXRbMF0uc2l6ZSgpOwogICAgCiAgICBtYXA8aW50LCB2ZWN0b3I8aW50Pj4gZGlhZ29uYWxzOwogICAgCiAgICAvLyBUcmF2ZXJzZSB0aGUgdG9wIHJvdyBhbmQgbGVmdCBjb2x1bW4gdG8gY3JlYXRlIGRpYWdvbmFscwogICAgZm9yIChpbnQgaSA9IDA7IGkgPCBtOyBpKyspIHsKICAgICAgICBmb3IgKGludCBqID0gMDsgaiA8IG47IGorKykgewogICAgICAgICAgICBkaWFnb25hbHNbaSAtIGpdLnB1c2hfYmFjayhtYXRbaV1bal0pOwogICAgICAgIH0KICAgIH0KICAgIAogICAgLy8gU29ydCBlYWNoIGRpYWdvbmFsCiAgICBmb3IgKGF1dG8mIGl0IDogZGlhZ29uYWxzKSB7CiAgICAgICAgc29ydChpdC5zZWNvbmQuYmVnaW4oKSwgaXQuc2Vjb25kLmVuZCgpLCBncmVhdGVyPGludD4oKSk7IC8vIFNvcnQgaW4gZGVzY2VuZGluZyBvcmRlcgogICAgfQogICAgCiAgICAvLyBGaWxsIHRoZSBzb3J0ZWQgdmFsdWVzIGJhY2sgaW50byB0aGUgbWF0cml4CiAgICBmb3IgKGludCBpID0gMDsgaSA8IG07IGkrKykgewogICAgICAgIGZvciAoaW50IGogPSAwOyBqIDwgbjsgaisrKSB7CiAgICAgICAgICAgIG1hdFtpXVtqXSA9IGRpYWdvbmFsc1tpIC0gal0uYmFjaygpOwogICAgICAgICAgICBkaWFnb25hbHNbaSAtIGpdLnBvcF9iYWNrKCk7CiAgICAgICAgfQogICAgfQogICAgCiAgICByZXR1cm4gbWF0Owp9CgppbnQgbWFpbigpIHsKICAgIGludCBtLCBuOwogICAgY2luID4+IG0gPj4gbjsKICAgIAogICAgdmVjdG9yPHZlY3RvcjxpbnQ+PiBtYXQobSwgdmVjdG9yPGludD4obikpOwogICAKICAgIAogICAgZm9yIChpbnQgaSA9IDA7IGkgPCBtOyBpKyspIHsKICAgICAgICBmb3IgKGludCBqID0gMDsgaiA8IG47IGorKykgewogICAgICAgICAgICBjaW4gPj4gbWF0W2ldW2pdOwogICAgICAgIH0KICAgIH0KICAgIAogICAgdmVjdG9yPHZlY3RvcjxpbnQ+PiBzb3J0ZWRNYXQgPSBkaWFnb25hbFNvcnQobWF0KTsKICAKICAgIGZvciAoaW50IGkgPSAwOyBpIDwgbTsgaSsrKSB7CiAgICAgICAgZm9yIChpbnQgaiA9IDA7IGogPCBuOyBqKyspIHsKICAgICAgICAgICAgY291dCA8PCBzb3J0ZWRNYXRbaV1bal0gPDwgIiAiOwogICAgICAgIH0KICAgICAgICBjb3V0IDw8IGVuZGw7CiAgICB9CiAgICAKICAgIHJldHVybiAwOwp9Cg==
Solution Java
aW1wb3J0IGphdmEudXRpbC4qOwoKcHVibGljIGNsYXNzIE1haW4gewogICAgcHVibGljIHN0YXRpYyB2b2lkIG1haW4oU3RyaW5nW10gYXJncykgewogICAgICAgIFNjYW5uZXIgc2Nhbm5lciA9IG5ldyBTY2FubmVyKFN5c3RlbS5pbik7CgogICAgICAgIC8vIFJlYWQgZGltZW5zaW9ucwogICAgICAgIGludCBtID0gc2Nhbm5lci5uZXh0SW50KCk7CiAgICAgICAgaW50IG4gPSBzY2FubmVyLm5leHRJbnQoKTsKICAgICAgICBpbnRbXVtdIG1hdCA9IG5ldyBpbnRbbV1bbl07CgogICAgICAgIC8vIFJlYWQgbWF0cml4IGVsZW1lbnRzCiAgICAgICAgZm9yIChpbnQgaSA9IDA7IGkgPCBtOyBpKyspIHsKICAgICAgICAgICAgZm9yIChpbnQgaiA9IDA7IGogPCBuOyBqKyspIHsKICAgICAgICAgICAgICAgIG1hdFtpXVtqXSA9IHNjYW5uZXIubmV4dEludCgpOwogICAgICAgICAgICB9CiAgICAgICAgfQoKICAgICAgICAvLyBNYXAgdG8gc3RvcmUgZGlhZ29uYWxzCiAgICAgICAgTWFwPEludGVnZXIsIExpc3Q8SW50ZWdlcj4+IGRpYWdvbmFscyA9IG5ldyBIYXNoTWFwPD4oKTsKCiAgICAgICAgLy8gR3JvdXAgZWxlbWVudHMgYnkgZGlhZ29uYWxzCiAgICAgICAgZm9yIChpbnQgaSA9IDA7IGkgPCBtOyBpKyspIHsKICAgICAgICAgICAgZm9yIChpbnQgaiA9IDA7IGogPCBuOyBqKyspIHsKICAgICAgICAgICAgICAgIGludCBrZXkgPSBpIC0gajsKICAgICAgICAgICAgICAgIGRpYWdvbmFscy5wdXRJZkFic2VudChrZXksIG5ldyBBcnJheUxpc3Q8PigpKTsKICAgICAgICAgICAgICAgIGRpYWdvbmFscy5nZXQoa2V5KS5hZGQobWF0W2ldW2pdKTsKICAgICAgICAgICAgfQogICAgICAgIH0KCiAgICAgICAgLy8gU29ydCBlYWNoIGRpYWdvbmFsCiAgICAgICAgZm9yIChMaXN0PEludGVnZXI+IGRpYWdvbmFsIDogZGlhZ29uYWxzLnZhbHVlcygpKSB7CiAgICAgICAgICAgIENvbGxlY3Rpb25zLnNvcnQoZGlhZ29uYWwpOwogICAgICAgIH0KCiAgICAgICAgLy8gUmVmaWxsIHRoZSBtYXRyaXggd2l0aCBzb3J0ZWQgZGlhZ29uYWxzCiAgICAgICAgZm9yIChpbnQgaSA9IDA7IGkgPCBtOyBpKyspIHsKICAgICAgICAgICAgZm9yIChpbnQgaiA9IDA7IGogPCBuOyBqKyspIHsKICAgICAgICAgICAgICAgIGludCBrZXkgPSBpIC0gajsKICAgICAgICAgICAgICAgIG1hdFtpXVtqXSA9IGRpYWdvbmFscy5nZXQoa2V5KS5yZW1vdmUoMCk7CiAgICAgICAgICAgIH0KICAgICAgICB9CgogICAgICAgIC8vIE91dHB1dCB0aGUgc29ydGVkIG1hdHJpeAogICAgICAgIGZvciAoaW50IGkgPSAwOyBpIDwgbTsgaSsrKSB7CiAgICAgICAgICAgIGZvciAoaW50IGogPSAwOyBqIDwgbjsgaisrKSB7CiAgICAgICAgICAgICAgICBTeXN0ZW0ub3V0LnByaW50KG1hdFtpXVtqXSArICIgIik7CiAgICAgICAgICAgIH0KICAgICAgICAgICAgU3lzdGVtLm91dC5wcmludGxuKCk7CiAgICAgICAgfQogICAgfQp9Cg==
Solution Python
IyBFbnRlciB5b3VyIGNvZGUgaGVyZS4gUmVhZCBpbnB1dCBmcm9tIFNURElOLiBQcmludCBvdXRwdXQgdG8gU1RET1VUDQphPWlucHV0KCkNCkE9YS5zcGxpdCgpDQptPWludChBWzBdKQ0Kbj1pbnQoQVsxXSkNCm1hdD1bXQ0KZm9yIGkgaW4gcmFuZ2UobSk6DQogIGI9aW5wdXQoKQ0KICBCPWIuc3BsaXQoKQ0KICBmb3IgaiBpbiByYW5nZShuKToNCiAgICBCW2pdPWludChCW2pdKQ0KICBtYXQuYXBwZW5kKEIpDQpmb3IgeSBpbiByYW5nZShuKToNCiAgbD1bXQ0KICBpPTANCiAgaj15DQogIHdoaWxlIGk8bSBhbmQgajxuOg0KICAgIGwuYXBwZW5kKGludChtYXRbaV1bal0pKQ0KICAgIGk9aSsxDQogICAgaj1qKzENCiAgbC5zb3J0KCkNCiAgaT0wDQogIGo9eQ0KICBmb3IgcCBpbiByYW5nZShsZW4obCkpOg0KICAgIG1hdFtpXVtqXT1sW3BdDQogICAgaT1pKzENCiAgICBqPWorMQ0KZm9yIHggaW4gcmFuZ2UobSk6DQogIGw9W10NCiAgaT14DQogIGo9MA0KICB3aGlsZSBpPG0gYW5kIGo8bjoNCiAgICBsLmFwcGVuZChpbnQobWF0W2ldW2pdKSkNCiAgICBpPWkrMQ0KICAgIGo9aisxDQogIGwuc29ydCgpDQogIGk9eA0KICBqPTANCiAgZm9yIHAgaW4gcmFuZ2UobGVuKGwpKToNCiAgICBtYXRbaV1bal09bFtwXQ0KICAgIGk9aSsxDQogICAgaj1qKzENCmZvciBxIGluIG1hdDoNCiAgZm9yIHIgaW4gcToNCiAgICBwcmludChyLCBlbmQ9JyAnKQ0KICBwcmludCgnJykNCg==
Problem Statement 5
Anna, a talented mathematician at the National Institute of Mathematics, was tasked with organizing a large collection of positive integers. She needed to find the smallest group of numbers (a subsequence) that, when removed from the collection, would leave her with a set of unique numbers.
The numbers in the subsequence had to be in non-decreasing order, and Anna only had a limited amount of time to complete the task. Help Anna identify and print the subsequence that, when taken from an array of length N, leaves her with a collection of distinct integers.
Since there may be multiple subsequences that can be removed to achieve this result, the subsequence that is both non-decreasing and smallest in length will be considered the optimal solution. If no such subsequence can be found, Anna must print -1.
Input Format
The first line contains an integer, N, the number of elements in the array Arr.
The next line contains N space-separated integers, denoting the array Arr.
Output Format
Print the subsequence that, when removed from the array, leaves Anna with a set of unique numbers. The resulting subsequence should be minimum in length and non-decreasing order. If such a suitable subsequence cannot be found, then print -1.
Constraints
1 <= N <= 10^5
1 <= Arr[i] <= 10^6
Solution C++
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CnZvaWQgc29sdmUodmVjdG9yPGludD4gYXJyKXsKICAgIG1hcDxpbnQsIHZlY3RvcjxpbnQ+PiBtOwoKICAgIGZvcihpbnQgaSA9IDA7IGkgPCBhcnIuc2l6ZSgpOyBpKyspewogICAgICAgIG1bYXJyW2ldXS5wdXNoX2JhY2soaSk7CiAgICB9CiAgICBpbnQgcHJldiA9IC0xOwogICAgdmVjdG9yPGludD4gYW5zOwogICAgZm9yKGF1dG8geDogbSl7CiAgICAgICAgaWYoeC5zZWNvbmQuc2l6ZSgpID4gMSl7CiAgICAgICAgICAgIGludCBjbnQgPSB4LnNlY29uZC5zaXplKCkgLSAxOwogICAgICAgICAgICBmb3IoYXV0byBudW1zOiB4LnNlY29uZCl7CiAgICAgICAgICAgICAgICBpZihudW1zID4gcHJldil7CiAgICAgICAgICAgICAgICAgICAgY250LS07CiAgICAgICAgICAgICAgICAgICAgcHJldiA9IG51bXM7CiAgICAgICAgICAgICAgICAgICAgYW5zLnB1c2hfYmFjayhhcnJbbnVtc10pOwogICAgICAgICAgICAgICAgfQogICAgICAgICAgICAgICAgaWYoY250ID09IDApIGJyZWFrOwogICAgICAgICAgICB9CiAgICAgICAgICAgIGlmKGNudCA+IDApewogICAgICAgICAgICAgICAgY291dCA8PCAiLTEiIDw8IGVuZGw7CiAgICAgICAgICAgICAgICByZXR1cm47CiAgICAgICAgICAgIH0KICAgICAgICB9CiAgICB9CiAgICBmb3IoaW50IHg6IGFucykgY291dCA8PCB4IDw8ICIgIjsKICAgIGNvdXQgPDwgZW5kbDsKfQoKaW50IG1haW4oKXsKICAgIGludCBOOyBjaW4gPj4gTjsKICAgIHZlY3RvcjxpbnQ+IGFycihOKTsKICAgIGZvcihpbnQgaSA9IDA7IGkgPCBOOyBpKyspIGNpbiA+PiBhcnJbaV07CiAgICBzb2x2ZShhcnIpOyAgCiAgICByZXR1cm4gMDsKfQo=
Solution Java
aW1wb3J0IGphdmEudXRpbC4qOwoKcHVibGljIGNsYXNzIE1haW4gewogICAgcHVibGljIHN0YXRpYyB2b2lkIHNvbHZlKExpc3Q8SW50ZWdlcj4gYXJyKSB7CiAgICAgICAgTWFwPEludGVnZXIsIExpc3Q8SW50ZWdlcj4+IG1hcCA9IG5ldyBIYXNoTWFwPD4oKTsKCiAgICAgICAgLy8gR3JvdXAgaW5kaWNlcyBieSBhcnJheSBlbGVtZW50CiAgICAgICAgZm9yIChpbnQgaSA9IDA7IGkgPCBhcnIuc2l6ZSgpOyBpKyspIHsKICAgICAgICAgICAgbWFwLnB1dElmQWJzZW50KGFyci5nZXQoaSksIG5ldyBBcnJheUxpc3Q8PigpKTsKICAgICAgICAgICAgbWFwLmdldChhcnIuZ2V0KGkpKS5hZGQoaSk7CiAgICAgICAgfQoKICAgICAgICBpbnQgcHJldiA9IC0xOwogICAgICAgIExpc3Q8SW50ZWdlcj4gYW5zID0gbmV3IEFycmF5TGlzdDw+KCk7CgogICAgICAgIC8vIFRyYXZlcnNlIHRoZSBtYXAgaW4gc29ydGVkIGtleSBvcmRlcgogICAgICAgIGZvciAoSW50ZWdlciBrZXkgOiBuZXcgVHJlZVNldDw+KG1hcC5rZXlTZXQoKSkpIHsKICAgICAgICAgICAgTGlzdDxJbnRlZ2VyPiBpbmRpY2VzID0gbWFwLmdldChrZXkpOwoKICAgICAgICAgICAgaWYgKGluZGljZXMuc2l6ZSgpID4gMSkgewogICAgICAgICAgICAgICAgaW50IGNudCA9IGluZGljZXMuc2l6ZSgpIC0gMTsKCiAgICAgICAgICAgICAgICBmb3IgKGludCBpbmRleCA6IGluZGljZXMpIHsKICAgICAgICAgICAgICAgICAgICBpZiAoaW5kZXggPiBwcmV2KSB7CiAgICAgICAgICAgICAgICAgICAgICAgIGNudC0tOwogICAgICAgICAgICAgICAgICAgICAgICBwcmV2ID0gaW5kZXg7CiAgICAgICAgICAgICAgICAgICAgICAgIGFucy5hZGQoYXJyLmdldChpbmRleCkpOwogICAgICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgICAgICAgICBpZiAoY250ID09IDApIGJyZWFrOwogICAgICAgICAgICAgICAgfQoKICAgICAgICAgICAgICAgIC8vIElmIHdlIGNhbm5vdCBzYXRpc2Z5IHRoZSBjb25kaXRpb24sIHByaW50IC0xIGFuZCByZXR1cm4KICAgICAgICAgICAgICAgIGlmIChjbnQgPiAwKSB7CiAgICAgICAgICAgICAgICAgICAgU3lzdGVtLm91dC5wcmludGxuKCItMSIpOwogICAgICAgICAgICAgICAgICAgIHJldHVybjsKICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgfQogICAgICAgIH0KCiAgICAgICAgLy8gUHJpbnQgdGhlIHJlc3VsdAogICAgICAgIGZvciAoaW50IHggOiBhbnMpIHsKICAgICAgICAgICAgU3lzdGVtLm91dC5wcmludCh4ICsgIiAiKTsKICAgICAgICB9CiAgICAgICAgU3lzdGVtLm91dC5wcmludGxuKCk7CiAgICB9CgogICAgcHVibGljIHN0YXRpYyB2b2lkIG1haW4oU3RyaW5nW10gYXJncykgewogICAgICAgIFNjYW5uZXIgc2MgPSBuZXcgU2Nhbm5lcihTeXN0ZW0uaW4pOwoKICAgICAgICAvLyBJbnB1dCBoYW5kbGluZwogICAgICAgIGludCBOID0gc2MubmV4dEludCgpOwogICAgICAgIExpc3Q8SW50ZWdlcj4gYXJyID0gbmV3IEFycmF5TGlzdDw+KCk7CiAgICAgICAgZm9yIChpbnQgaSA9IDA7IGkgPCBOOyBpKyspIHsKICAgICAgICAgICAgYXJyLmFkZChzYy5uZXh0SW50KCkpOwogICAgICAgIH0KCiAgICAgICAgc29sdmUoYXJyKTsKICAgIH0KfQo=
Solution Python
ZGVmIHNvbHZlKGFycik6DQogICAgZnJvbSBjb2xsZWN0aW9ucyBpbXBvcnQgZGVmYXVsdGRpY3QNCg0KICAgICMgR3JvdXAgaW5kaWNlcyBieSBhcnJheSBlbGVtZW50DQogICAgZ3JvdXBlZF9pbmRpY2VzID0gZGVmYXVsdGRpY3QobGlzdCkNCiAgICBmb3IgaSwgdmFsIGluIGVudW1lcmF0ZShhcnIpOg0KICAgICAgICBncm91cGVkX2luZGljZXNbdmFsXS5hcHBlbmQoaSkNCg0KICAgIHByZXYgPSAtMQ0KICAgIGFucyA9IFtdDQoNCiAgICAjIFRyYXZlcnNlIHRoZSBncm91cGVkIGluZGljZXMgaW4gc29ydGVkIGtleSBvcmRlcg0KICAgIGZvciBrZXkgaW4gc29ydGVkKGdyb3VwZWRfaW5kaWNlcy5rZXlzKCkpOg0KICAgICAgICBpbmRpY2VzID0gZ3JvdXBlZF9pbmRpY2VzW2tleV0NCg0KICAgICAgICBpZiBsZW4oaW5kaWNlcykgPiAxOg0KICAgICAgICAgICAgY250ID0gbGVuKGluZGljZXMpIC0gMQ0KDQogICAgICAgICAgICBmb3IgaW5kZXggaW4gaW5kaWNlczoNCiAgICAgICAgICAgICAgICBpZiBpbmRleCA+IHByZXY6DQogICAgICAgICAgICAgICAgICAgIGNudCAtPSAxDQogICAgICAgICAgICAgICAgICAgIHByZXYgPSBpbmRleA0KICAgICAgICAgICAgICAgICAgICBhbnMuYXBwZW5kKGFycltpbmRleF0pDQogICAgICAgICAgICAgICAgaWYgY250ID09IDA6DQogICAgICAgICAgICAgICAgICAgIGJyZWFrDQoNCiAgICAgICAgICAgICMgSWYgd2UgY2Fubm90IHNhdGlzZnkgdGhlIGNvbmRpdGlvbiwgcHJpbnQgLTEgYW5kIHJldHVybg0KICAgICAgICAgICAgaWYgY250ID4gMDoNCiAgICAgICAgICAgICAgICBwcmludCgtMSkNCiAgICAgICAgICAgICAgICByZXR1cm4NCg0KICAgICMgUHJpbnQgdGhlIHJlc3VsdA0KICAgIHByaW50KCIgIi5qb2luKG1hcChzdHIsIGFucykpKQ0KDQoNCmRlZiBtYWluKCk6DQogICAgIyBJbnB1dCBoYW5kbGluZw0KICAgIE4gPSBpbnQoaW5wdXQoKSkNCiAgICBhcnIgPSBsaXN0KG1hcChpbnQsIGlucHV0KCkuc3BsaXQoKSkpDQogICAgc29sdmUoYXJyKQ0KDQoNCmlmIF9fbmFtZV9fID09ICJfX21haW5fXyI6DQogICAgbWFpbigpDQo=
Conclusion
Cracking IBM’s coding assessment requires focused preparation and a strategic approach. By thoroughly understanding the test pattern and practicing the previous year's coding questions, you can significantly enhance your chances of success.
Stay consistent, sharpen your logic, and approach the test with confidence. Good luck!
Frequently Asked Questions (FAQs)
1. What is the structure of IBM’s coding assessment?
It comprises a mix of MCQs and 1-2 coding problems designed to evaluate programming proficiency and logical reasoning.
2. Which languages can I use for coding questions?
Commonly supported languages include Java, Python, C++, and C.
3. Are IBM’s previous year's questions repetitive?
While questions aren’t repeated verbatim, similar patterns and logic are often tested.
4. Where can I find IBM’s previous coding questions?
IBM does not officially release past questions. However, you can find curated examples on trusted online forums and platforms.
5. Can I expect dynamic programming problems in the coding test?
Yes, basic to intermediate-level dynamic programming problems are often included.
Disclaimer: While we strive for accuracy, we do not guarantee its completeness or reliability. Readers are encouraged to verify all facts and statistics from the official company website or check independently before making decisions.
Suggested reads:
- Accenture Coding Questions: 5 Coding Solutions for Freshers 2025
- HCL Coding Questions: Coding Pattern with Questions & Solutions
- TCS Ninja Coding Questions: Top 5 Coding Questions with Solution
- Deloitte Coding Questions: Top 5 Coding Questions for Freshers
- TCS Digital Coding Questions: Top 5 Coding Questions & Solutions
Instinctively, I fall for nature, music, humour, reading, writing, listening, travelling, observing, learning, unlearning, friendship, exercise, etc., all these from the cradle to the grave- that's ME! It's my irrefutable belief in the uniqueness of all. I'll vehemently defend your right to be your best while I expect the same from you!
Login to continue reading
And access exclusive content, personalized recommendations, and career-boosting opportunities.
Subscribe
to our newsletter
Comments
Add comment