It was a telephonic discussion session for the post of senior software developer. Though I could not clear the round yet it would be best place to share the questions so that I can discuss whether there can be other solutions for the problems asked.
However when things are user's point, then it is required to provide administrative work to someone who can create group, assign group, and perform group related works. It is required to add few fields and methods in other classes as well.
However we can add more to it, but till this point we discussed.
- What are the differences between JDK, JRE, and JVM?
JDK (Java Development Kit): Development Kit which is actually required for the developers. It is not required to run the Java dependent applications. It is rather required at the development.
JRE (Java Runtime Environment): Java Runtime environment is required to run the java application. It computer does not JRE, No Java application can run on it.
JVM (Java Virtual Machine): JVM is part of JRE, it reads byte code and execute them on the Hardware. It is the reason which causes JAVA applications to run on various platforms without changing much at the program level.
- Design Problem: You have to build a data/class model for a website. It has users i.e. People and it has group. A User can belong to multiple groups and a Group can have multiple users. Each group maintains an individual account. All the transactions are saved with the person who made the expenses and each person's share is calculated on each transaction. Person vice credit/debit history should also be maintained. Build the data structure for the same.
Design problems are some problem when interviewer and interviewee both do not have same understanding of the requirement. Such problems must only be discussed when you are speaking face to face. It not only gives more confidence but also provides more error correction while writing the code.
For this specific design problem, I had assumed that group is the prime information that system has, whereas Interviewer was expecting that Person should be the prima facie of the complete system. Though it was not difficult both the ways, but it is planned in separate way for both entities.
First Design
Application would have four classes as following
1: public class Group{
2: List<Person> members;
3: List<Transaction> transactions;
4: List<Share> shares;
5: double totalExpenditure;
6: //Methods
7: addPerson
8: addTransaction
9: settleAmount
10: getShare for a person
11: }
12: public class Person{
13: String name;
14: List<Group> groups;
15: double credit;
16: double debit;
17: //Method
18: addToCredit
19: addToDebit
20: addGroup
21: }
22: public class Share{
23: double credit;
24: double debit;
25: Person belongsTo;
26: //Changes with each transaction.
27: }
28: //Transaction once added, it would be required it to modify.
29: public final class Transaction{ //Immutable class
30: final String type;
31: final String expenseReason;
32: final double amount;
33: final Person spentBy;
34: public Transaction(final String t, final String r, final double amount, final Person p){
35: type = t;
36: expenseReason = r;
37: this.amount = amount;
38: spentBy = p;
39: }
40: }
Now when the system is designed from group point of view, it is considered that group is self managed and everyone part of the group would really be part of all the transactions relevant to group.
All the classes are self explanatory. Why did I make Transaction as immutable? Transaction is once done, it can not be altered later. Though there can be people who would say that 'What if user inputs the wrong data?' Oh yes, user has rights to enter wrong data, but it would be atmost 1% times.
It is best to solve the problems which are essential rather increase the complexity of the system by solving trivial problems.
However interviewer wanted to run things with the user perspective. As per him, A group is an entity based on users. User may or may not be the part of group's particular transactions. So it was required to rewrite the classes again based on the following assumption.
//Transaction once added, it would not be required to modify it.
public final class Transaction{
final String type;
final String expenseReason;
final double amount;
final Person spentBy;
final List<Person> sharedAmong;
public Transaction(final String t, final String r, final double amount, final Person p, final List<Person> shared){
type = t;
expenseReason = r;
this.amount = amount;
spentBy = p;
sharedAmong = Collections.unmodifiableList(shared);
}
}
However when things are user's point, then it is required to provide administrative work to someone who can create group, assign group, and perform group related works. It is required to add few fields and methods in other classes as well.
public class Group{
List<Person> admins;
.....
}
public class Person{
....
createGroup
addAdminToTheGroup
invitePeople
}
However we can add more to it, but till this point we discussed.
- Algorithm Problem: A random string is provided to you, you must find the minimum number of elements to be inserted in the string to make it palindrome.
- String is ABA, then method must return 0.
- String is ABC, then method must return 2 to form ABCBA.
- String ABCDA, then method must return 2 to form ABCDCBA.
- String ASD3D5, then method must return 3 to form AS5D3D5SA.
It would be best to save to Algorithm Problem for the next blog. I could not solve the problem at the time of interview, but I have a solution with O(n*n) complexity. If there is solution available which is better than this, please suggest me.
If you think that above design problem can be designed better, please suggest.
No comments:
Post a Comment