Tuesday, August 5, 2008

TopCoder: UserName

URL

http://www.topcoder.com/stat?c=problem_statement&pm=2913&rd=5849

Problem Statement


You are implementing the member registration system of an online dating site. When a new member signs up, it is possible that she initially chooses the same username as an existing member. The system must then inform the new member of the conflict and suggest a variant of the chosen name with a number attached to the end.

If an existing member is named "FunkyMonkey", for example, and a new member wants the same username, the simplest suggestion the system can make is "FunkyMonkey1". If there is already a member by that name, the system must suggest "FunkyMonkey2", unless that variant is also taken. If all names from "FunkyMonkey1" through "FunkyMonkey9" are taken as well as the original "FunkyMonkey", the system moves on to consider "FunkyMonkey10", and so on. The goal is to use the smallest possible number in the variant. Note that each username consists of letters (the characters from 'a' to 'z' and from 'A' to 'Z') and numerals ('0' to '9').

You are given a String[], existingNames, containing all usernames that have already been registered in the system. You are also given a single String, newName, containing the username that a new member wants to use. In the event of a conflict, this member will accept the suggestion offered by your system in accordance with the principles above. Return a String containing the username finally assigned to the new member.


Definition


Class:UserName
Method:newMember
Parameters:String[], String
Returns:String
Method signature:String newMember(String[] existingNames, String newName)
(be sure your method is public)



Notes

-The constraints rule out names that end in a number with a leading zero, such as "grokster006" and "bart0".

Constraints

-existingNames contains between 1 and 50 elements, inclusive
-each element of existingNames is between 1 and 50 characters long, inclusive
-the only characters permitted in elements of existingNames are 'a' to 'z', 'A' to 'Z', and '0' to '9'
-no element of existingNames ends in a number that has a leading zero
-newName is between 1 and 50 characters long, inclusive
-the only characters permitted in newName are 'a' to 'z' and 'A' to 'Z'

Examples

0)

{"MasterOfDisaster", "DingBat", "Orpheus", "WolfMan", "MrKnowItAll"}
"TygerTyger"
Returns: "TygerTyger"
"TygerTyger" is available.
1)

{"MasterOfDisaster", "TygerTyger1", "DingBat", "Orpheus",
"TygerTyger", "WolfMan", "MrKnowItAll"}
"TygerTyger"
Returns: "TygerTyger2"
"TygerTyger" and "TygerTyger1" are taken.
2)

{"TygerTyger2000", "TygerTyger1", "MasterDisaster", "DingBat",
"Orpheus", "WolfMan", "MrKnowItAll"}
"TygerTyger"
Returns: "TygerTyger"
There are higher-numbered variants of "TygerTyger", but the base name is available.
3)

{"grokster2", "BrownEyedBoy", "Yoop", "BlueEyedGirl",
"grokster", "Elemental", "NightShade", "Grokster1"}
"grokster"
Returns: "grokster1"
Note that "Grokster1" is not the same as "grokster1".
4)

{"Bart4", "Bart5", "Bart6", "Bart7", "Bart8", "Bart9", "Bart10",
"Lisa", "Marge", "Homer", "Bart", "Bart1", "Bart2", "Bart3",
"Bart11", "Bart12"}
"Bart"
Returns: "Bart13"


Solution



import java.util.*;
public class UserName{

public String newMember(String[] existingNames, String newName){
String regex = "^"+newName+"[0-9]*$";
List<String> abc =new ArrayList<String>();
List<Integer> xyz =new ArrayList<Integer>();
for (String a: existingNames){
if (a.matches(regex)) {
abc.add(a);
xyz.add(new Integer(a.replace(newName,"0")));
}
}
if (abc.size()==0 || !abc.contains(newName)){
return newName;
}
//Collections.sort(abc);
Collections.sort(xyz);
for (int i=0;i<xyz.size();i++){
if (xyz.get(i)!=i){
return newName+(i==0?"":i);
}
}
return newName+(xyz.size());
}

public static void main(String[] args){
UserName un = new UserName();
System.out.println(un.newMember(new String[]{"MasterOfDisaster", "DingBat", "Orpheus", "WolfMan", "MrKnowItAll"},"TygerTyger"));
System.out.println(un.newMember(new String[]{"MasterOfDisaster", "TygerTyger1", "DingBat", "Orpheus",
"TygerTyger", "WolfMan", "MrKnowItAll"},"TygerTyger"));
System.out.println(un.newMember(new String[]{"TygerTyger2000", "TygerTyger1", "MasterDisaster", "DingBat", "Orpheus", "WolfMan", "MrKnowItAll"},"TygerTyger"));
System.out.println(un.newMember(new String[]{"grokster2", "BrownEyedBoy", "Yoop", "BlueEyedGirl",
"grokster", "Elemental", "NightShade", "Grokster1"},"grokster"));
System.out.println(un.newMember(new String[]{"Bart4", "Bart5", "Bart6", "Bart7", "Bart8", "Bart9", "Bart10",
"Lisa", "Marge", "Homer", "Bart", "Bart1", "Bart2", "Bart3",
"Bart11", "Bart12"},"Bart"));
}
}

No comments: