Hackerrank All Women's Codesprint 2019: Name the Product The Next CEO of Stack OverflowMaximizing XOR HackerRank challengeHackerRank Regex Challenge: Detect HTML TagsProject Euler #8 - Largest product in seriesTime Limit Exceeded for build_max_heapFinding shortest sequences of integers whose product is larger than nOptimize Performance challenge 'Vinay Queried 'Find the number of substrings of a numerical string greater than a given num stringHackerRank university codesprint array constructionHackerrank: Sherlock and anagram (optimal time complexity)Hackerrank: Prefix neighbors

Science fiction (dystopian) short story set after WWIII

Is it okay to store user locations?

Need some help with wall behind rangetop

How do scammers retract money, while you can’t?

Is it safe to use c_str() on a temporary string?

How to make a variable always equal to the result of some calculations?

How easy is it to start Magic from scratch?

Implement the Thanos sorting algorithm

How to write the block matrix in LaTex?

Rotate a column

How long to clear the 'suck zone' of a turbofan after start is initiated?

How to start emacs in "nothing" mode (`fundamental-mode`)

WOW air has ceased operation, can I get my tickets refunded?

Text adventure game code

How to make a software documentation "officially" citable?

How did people program for Consoles with multiple CPUs?

How do I solve this limit?

Grabbing quick drinks

What is the difference between "behavior" and "behaviour"?

Robert Sheckley short story about vacation spots being overwhelmed

Only print output after finding pattern

Can the Reverse Gravity spell affect the Meteor Swarm spell?

Opposite of a diet

Term for the "extreme-extension" version of a straw man fallacy?



Hackerrank All Women's Codesprint 2019: Name the Product



The Next CEO of Stack OverflowMaximizing XOR HackerRank challengeHackerRank Regex Challenge: Detect HTML TagsProject Euler #8 - Largest product in seriesTime Limit Exceeded for build_max_heapFinding shortest sequences of integers whose product is larger than nOptimize Performance challenge 'Vinay Queried 'Find the number of substrings of a numerical string greater than a given num stringHackerRank university codesprint array constructionHackerrank: Sherlock and anagram (optimal time complexity)Hackerrank: Prefix neighbors










4












$begingroup$


Link: https://www.hackerrank.com/contests/hackerrank-all-womens-codesprint-2019/challenges/name-the-product/



Problem




You are contesting to name a new product in your company given the following conditions:



You are given an array of $n$ different names, $names$, where $names_i$ denotes the $i^th$ name and all the names are of length $5$. The distance between any two names is the number of positions in which the characters in these names differ. For example, "bubby" and "bunny" differ in two positions.



You have to choose a name such that the sum of differences of all names in $names$ with the chosen name is maximal. In order to win the contest, give the new product this chosen name.



Note: If there are many such names chose the lexicographically largest one.



Take for example, names = ["bubby", "bunny", "berry"], with length $n = 3$. Then, the name that you should choose is "zzzzz" as this name has no common character with any name in the names list and is also lexicographically the largest.



Function Description



Complete the productName function in the editor below. It should return the lexigraphically largest string of length whose sum of differences with all the names is maximal.



productName has the following parameter(s):



names: array of $n$ names



Input Format



  • The first line contains an integer, $n$, denoting the number of elements in $names$.

  • Each line $i$ of the $n$ subsequent lines (where $0 le i le n$) contains a string describing $names_i$.

Constraints



  • $1 le n le 10^5$

  • All characters in the names are lowercase English alphabets.

  • Each name is of length $5$.

Output Format



  • The output should contain the lexigraphically largest string of length whose sum of differences with all the names is maximal.

Sample Input 0



3
bubby
bunny
berry


Sample Output 0



zzzzz


Explanation 0



  • Difference between $names_0$, bubby, and zzzzz is $5$.

  • Difference between $names_1$, bunny, and zzzzz is $5$.

  • Difference between $names_2$, berry, and zzzzz is $5$.
    So, total difference is 15, which is maximal.

Sample Input 1



3
ready
stedy
zebra


Sample Output 1



yzzzz


Explanation 1



  • Difference between $names_0$, ready, and yzzzz is $5$.

  • Difference between $names_1$, stedy, and yzzzz is $5$.

  • Difference between $names_2$, zebra, and yzzzz is $5$.
    So, total differce is 15, which is maximal.





I would strip the extraneous parts from my solution:



import math, os, random, re, sys
from collections import defaultdict as dd, Counter as count

alphabet = "abcdefghijklmnopqrstuvwxyz"
def productName(names):
charmap = [dd(lambda: 0, count(name[i] for name in names)) for i in range(5)]
return "".join(max(alphabet, key=lambda x: (-charmap[i][x], x)) for i in range(5))


I'm concerned with adhering to best practices and maximising performance.










share|improve this question









$endgroup$











  • $begingroup$
    Meta comment, writing up the question took me much more time than actually solving the question due to the copious amounts of formatting involved. I would likely submit more questions from this particular codesprint, would leaving out the problem description and merely dropping the link be acceptable?
    $endgroup$
    – Tobi Alafin
    Mar 18 at 10:38






  • 11




    $begingroup$
    Absolutely not.
    $endgroup$
    – Mast
    Mar 18 at 10:41






  • 3




    $begingroup$
    See Can I include problem statements when posting exercise solutions to Code Review?. In short, a link alone is not sufficient (the question must be complete in itself), but you may need to write the requirements in your own words - unless you have specific permission to copy and republish.
    $endgroup$
    – Toby Speight
    Mar 18 at 10:43










  • $begingroup$
    I think online programming challenges are by default public domain?
    $endgroup$
    – Tobi Alafin
    Mar 18 at 10:46






  • 3




    $begingroup$
    @TobySpeight Although it's unlikely to be deleted by the community, since the community is explicitly not tasked with legal enforcement. That's SE-employees territory, it goes even beyond the moderators.
    $endgroup$
    – Mast
    Mar 18 at 12:52















4












$begingroup$


Link: https://www.hackerrank.com/contests/hackerrank-all-womens-codesprint-2019/challenges/name-the-product/



Problem




You are contesting to name a new product in your company given the following conditions:



You are given an array of $n$ different names, $names$, where $names_i$ denotes the $i^th$ name and all the names are of length $5$. The distance between any two names is the number of positions in which the characters in these names differ. For example, "bubby" and "bunny" differ in two positions.



You have to choose a name such that the sum of differences of all names in $names$ with the chosen name is maximal. In order to win the contest, give the new product this chosen name.



Note: If there are many such names chose the lexicographically largest one.



Take for example, names = ["bubby", "bunny", "berry"], with length $n = 3$. Then, the name that you should choose is "zzzzz" as this name has no common character with any name in the names list and is also lexicographically the largest.



Function Description



Complete the productName function in the editor below. It should return the lexigraphically largest string of length whose sum of differences with all the names is maximal.



productName has the following parameter(s):



names: array of $n$ names



Input Format



  • The first line contains an integer, $n$, denoting the number of elements in $names$.

  • Each line $i$ of the $n$ subsequent lines (where $0 le i le n$) contains a string describing $names_i$.

Constraints



  • $1 le n le 10^5$

  • All characters in the names are lowercase English alphabets.

  • Each name is of length $5$.

Output Format



  • The output should contain the lexigraphically largest string of length whose sum of differences with all the names is maximal.

Sample Input 0



3
bubby
bunny
berry


Sample Output 0



zzzzz


Explanation 0



  • Difference between $names_0$, bubby, and zzzzz is $5$.

  • Difference between $names_1$, bunny, and zzzzz is $5$.

  • Difference between $names_2$, berry, and zzzzz is $5$.
    So, total difference is 15, which is maximal.

Sample Input 1



3
ready
stedy
zebra


Sample Output 1



yzzzz


Explanation 1



  • Difference between $names_0$, ready, and yzzzz is $5$.

  • Difference between $names_1$, stedy, and yzzzz is $5$.

  • Difference between $names_2$, zebra, and yzzzz is $5$.
    So, total differce is 15, which is maximal.





I would strip the extraneous parts from my solution:



import math, os, random, re, sys
from collections import defaultdict as dd, Counter as count

alphabet = "abcdefghijklmnopqrstuvwxyz"
def productName(names):
charmap = [dd(lambda: 0, count(name[i] for name in names)) for i in range(5)]
return "".join(max(alphabet, key=lambda x: (-charmap[i][x], x)) for i in range(5))


I'm concerned with adhering to best practices and maximising performance.










share|improve this question









$endgroup$











  • $begingroup$
    Meta comment, writing up the question took me much more time than actually solving the question due to the copious amounts of formatting involved. I would likely submit more questions from this particular codesprint, would leaving out the problem description and merely dropping the link be acceptable?
    $endgroup$
    – Tobi Alafin
    Mar 18 at 10:38






  • 11




    $begingroup$
    Absolutely not.
    $endgroup$
    – Mast
    Mar 18 at 10:41






  • 3




    $begingroup$
    See Can I include problem statements when posting exercise solutions to Code Review?. In short, a link alone is not sufficient (the question must be complete in itself), but you may need to write the requirements in your own words - unless you have specific permission to copy and republish.
    $endgroup$
    – Toby Speight
    Mar 18 at 10:43










  • $begingroup$
    I think online programming challenges are by default public domain?
    $endgroup$
    – Tobi Alafin
    Mar 18 at 10:46






  • 3




    $begingroup$
    @TobySpeight Although it's unlikely to be deleted by the community, since the community is explicitly not tasked with legal enforcement. That's SE-employees territory, it goes even beyond the moderators.
    $endgroup$
    – Mast
    Mar 18 at 12:52













4












4








4


1



$begingroup$


Link: https://www.hackerrank.com/contests/hackerrank-all-womens-codesprint-2019/challenges/name-the-product/



Problem




You are contesting to name a new product in your company given the following conditions:



You are given an array of $n$ different names, $names$, where $names_i$ denotes the $i^th$ name and all the names are of length $5$. The distance between any two names is the number of positions in which the characters in these names differ. For example, "bubby" and "bunny" differ in two positions.



You have to choose a name such that the sum of differences of all names in $names$ with the chosen name is maximal. In order to win the contest, give the new product this chosen name.



Note: If there are many such names chose the lexicographically largest one.



Take for example, names = ["bubby", "bunny", "berry"], with length $n = 3$. Then, the name that you should choose is "zzzzz" as this name has no common character with any name in the names list and is also lexicographically the largest.



Function Description



Complete the productName function in the editor below. It should return the lexigraphically largest string of length whose sum of differences with all the names is maximal.



productName has the following parameter(s):



names: array of $n$ names



Input Format



  • The first line contains an integer, $n$, denoting the number of elements in $names$.

  • Each line $i$ of the $n$ subsequent lines (where $0 le i le n$) contains a string describing $names_i$.

Constraints



  • $1 le n le 10^5$

  • All characters in the names are lowercase English alphabets.

  • Each name is of length $5$.

Output Format



  • The output should contain the lexigraphically largest string of length whose sum of differences with all the names is maximal.

Sample Input 0



3
bubby
bunny
berry


Sample Output 0



zzzzz


Explanation 0



  • Difference between $names_0$, bubby, and zzzzz is $5$.

  • Difference between $names_1$, bunny, and zzzzz is $5$.

  • Difference between $names_2$, berry, and zzzzz is $5$.
    So, total difference is 15, which is maximal.

Sample Input 1



3
ready
stedy
zebra


Sample Output 1



yzzzz


Explanation 1



  • Difference between $names_0$, ready, and yzzzz is $5$.

  • Difference between $names_1$, stedy, and yzzzz is $5$.

  • Difference between $names_2$, zebra, and yzzzz is $5$.
    So, total differce is 15, which is maximal.





I would strip the extraneous parts from my solution:



import math, os, random, re, sys
from collections import defaultdict as dd, Counter as count

alphabet = "abcdefghijklmnopqrstuvwxyz"
def productName(names):
charmap = [dd(lambda: 0, count(name[i] for name in names)) for i in range(5)]
return "".join(max(alphabet, key=lambda x: (-charmap[i][x], x)) for i in range(5))


I'm concerned with adhering to best practices and maximising performance.










share|improve this question









$endgroup$




Link: https://www.hackerrank.com/contests/hackerrank-all-womens-codesprint-2019/challenges/name-the-product/



Problem




You are contesting to name a new product in your company given the following conditions:



You are given an array of $n$ different names, $names$, where $names_i$ denotes the $i^th$ name and all the names are of length $5$. The distance between any two names is the number of positions in which the characters in these names differ. For example, "bubby" and "bunny" differ in two positions.



You have to choose a name such that the sum of differences of all names in $names$ with the chosen name is maximal. In order to win the contest, give the new product this chosen name.



Note: If there are many such names chose the lexicographically largest one.



Take for example, names = ["bubby", "bunny", "berry"], with length $n = 3$. Then, the name that you should choose is "zzzzz" as this name has no common character with any name in the names list and is also lexicographically the largest.



Function Description



Complete the productName function in the editor below. It should return the lexigraphically largest string of length whose sum of differences with all the names is maximal.



productName has the following parameter(s):



names: array of $n$ names



Input Format



  • The first line contains an integer, $n$, denoting the number of elements in $names$.

  • Each line $i$ of the $n$ subsequent lines (where $0 le i le n$) contains a string describing $names_i$.

Constraints



  • $1 le n le 10^5$

  • All characters in the names are lowercase English alphabets.

  • Each name is of length $5$.

Output Format



  • The output should contain the lexigraphically largest string of length whose sum of differences with all the names is maximal.

Sample Input 0



3
bubby
bunny
berry


Sample Output 0



zzzzz


Explanation 0



  • Difference between $names_0$, bubby, and zzzzz is $5$.

  • Difference between $names_1$, bunny, and zzzzz is $5$.

  • Difference between $names_2$, berry, and zzzzz is $5$.
    So, total difference is 15, which is maximal.

Sample Input 1



3
ready
stedy
zebra


Sample Output 1



yzzzz


Explanation 1



  • Difference between $names_0$, ready, and yzzzz is $5$.

  • Difference between $names_1$, stedy, and yzzzz is $5$.

  • Difference between $names_2$, zebra, and yzzzz is $5$.
    So, total differce is 15, which is maximal.





I would strip the extraneous parts from my solution:



import math, os, random, re, sys
from collections import defaultdict as dd, Counter as count

alphabet = "abcdefghijklmnopqrstuvwxyz"
def productName(names):
charmap = [dd(lambda: 0, count(name[i] for name in names)) for i in range(5)]
return "".join(max(alphabet, key=lambda x: (-charmap[i][x], x)) for i in range(5))


I'm concerned with adhering to best practices and maximising performance.







python performance beginner programming-challenge






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Mar 18 at 10:37









Tobi AlafinTobi Alafin

643110




643110











  • $begingroup$
    Meta comment, writing up the question took me much more time than actually solving the question due to the copious amounts of formatting involved. I would likely submit more questions from this particular codesprint, would leaving out the problem description and merely dropping the link be acceptable?
    $endgroup$
    – Tobi Alafin
    Mar 18 at 10:38






  • 11




    $begingroup$
    Absolutely not.
    $endgroup$
    – Mast
    Mar 18 at 10:41






  • 3




    $begingroup$
    See Can I include problem statements when posting exercise solutions to Code Review?. In short, a link alone is not sufficient (the question must be complete in itself), but you may need to write the requirements in your own words - unless you have specific permission to copy and republish.
    $endgroup$
    – Toby Speight
    Mar 18 at 10:43










  • $begingroup$
    I think online programming challenges are by default public domain?
    $endgroup$
    – Tobi Alafin
    Mar 18 at 10:46






  • 3




    $begingroup$
    @TobySpeight Although it's unlikely to be deleted by the community, since the community is explicitly not tasked with legal enforcement. That's SE-employees territory, it goes even beyond the moderators.
    $endgroup$
    – Mast
    Mar 18 at 12:52
















  • $begingroup$
    Meta comment, writing up the question took me much more time than actually solving the question due to the copious amounts of formatting involved. I would likely submit more questions from this particular codesprint, would leaving out the problem description and merely dropping the link be acceptable?
    $endgroup$
    – Tobi Alafin
    Mar 18 at 10:38






  • 11




    $begingroup$
    Absolutely not.
    $endgroup$
    – Mast
    Mar 18 at 10:41






  • 3




    $begingroup$
    See Can I include problem statements when posting exercise solutions to Code Review?. In short, a link alone is not sufficient (the question must be complete in itself), but you may need to write the requirements in your own words - unless you have specific permission to copy and republish.
    $endgroup$
    – Toby Speight
    Mar 18 at 10:43










  • $begingroup$
    I think online programming challenges are by default public domain?
    $endgroup$
    – Tobi Alafin
    Mar 18 at 10:46






  • 3




    $begingroup$
    @TobySpeight Although it's unlikely to be deleted by the community, since the community is explicitly not tasked with legal enforcement. That's SE-employees territory, it goes even beyond the moderators.
    $endgroup$
    – Mast
    Mar 18 at 12:52















$begingroup$
Meta comment, writing up the question took me much more time than actually solving the question due to the copious amounts of formatting involved. I would likely submit more questions from this particular codesprint, would leaving out the problem description and merely dropping the link be acceptable?
$endgroup$
– Tobi Alafin
Mar 18 at 10:38




$begingroup$
Meta comment, writing up the question took me much more time than actually solving the question due to the copious amounts of formatting involved. I would likely submit more questions from this particular codesprint, would leaving out the problem description and merely dropping the link be acceptable?
$endgroup$
– Tobi Alafin
Mar 18 at 10:38




11




11




$begingroup$
Absolutely not.
$endgroup$
– Mast
Mar 18 at 10:41




$begingroup$
Absolutely not.
$endgroup$
– Mast
Mar 18 at 10:41




3




3




$begingroup$
See Can I include problem statements when posting exercise solutions to Code Review?. In short, a link alone is not sufficient (the question must be complete in itself), but you may need to write the requirements in your own words - unless you have specific permission to copy and republish.
$endgroup$
– Toby Speight
Mar 18 at 10:43




$begingroup$
See Can I include problem statements when posting exercise solutions to Code Review?. In short, a link alone is not sufficient (the question must be complete in itself), but you may need to write the requirements in your own words - unless you have specific permission to copy and republish.
$endgroup$
– Toby Speight
Mar 18 at 10:43












$begingroup$
I think online programming challenges are by default public domain?
$endgroup$
– Tobi Alafin
Mar 18 at 10:46




$begingroup$
I think online programming challenges are by default public domain?
$endgroup$
– Tobi Alafin
Mar 18 at 10:46




3




3




$begingroup$
@TobySpeight Although it's unlikely to be deleted by the community, since the community is explicitly not tasked with legal enforcement. That's SE-employees territory, it goes even beyond the moderators.
$endgroup$
– Mast
Mar 18 at 12:52




$begingroup$
@TobySpeight Although it's unlikely to be deleted by the community, since the community is explicitly not tasked with legal enforcement. That's SE-employees territory, it goes even beyond the moderators.
$endgroup$
– Mast
Mar 18 at 12:52










1 Answer
1






active

oldest

votes


















15












$begingroup$

Imports



import math, os, random, re, sys
from collections import defaultdict as dd, Counter as count


Seriously, don't do this. It may be useful to read PEP8 regarding imports again.



  • Imports should be on separate lines.


  • Why do Counter as count? It impairs readability.



    Especially in larger scripts, every Python dev knows Counter, but count could be a random variable and is easy to be overshadowed.



  • You don't use all of the imported modules; just remove them if you don't need them.



  • alphabet = "abcdefghijklmnopqrstuvwxyz"


    Here you missed something that is in the standard lib: from string import ascii_lowercase



Misc




  • This dd(lambda: 0, ... adds no value



    Counter is already a dictionary with default value 0 just remove that part




  • Magic numbers



    5 is a Magic number, you should define it as a CONSTANT:



    NAME_LENGTH = 5


The rest looks good!






share|improve this answer











$endgroup$








  • 6




    $begingroup$
    May as well avoid aliasing defaultdict, too. Who the heck is going to know what dd is if they skip past the imports?
    $endgroup$
    – jpmc26
    Mar 18 at 18:28










  • $begingroup$
    They're fault for skipping past the imports IMO. shrugs
    $endgroup$
    – Tobi Alafin
    Mar 18 at 18:59






  • 5




    $begingroup$
    Respectfully no, the same advice goes for aliasing defaultdict. In this small example it doesn't matter, and it's easy to read, but when you are working on larger projects this can be a true pain in the ***
    $endgroup$
    – Ludisposed
    Mar 18 at 19:03






  • 6




    $begingroup$
    @TobiAlafin You need to learn the Principle of Least Astonishment. The biggest thing you should do to make your code readable and maintainable is to avoid doing things that are surprising. Aliasing something that's referenced exactly once is the code is weird. It's surprising. So is abbreviating names from the standard library. Don't do things that will surprise other developers. Do normal things. Great code is so obvious, it makes you think you could have easily thought of it.
    $endgroup$
    – jpmc26
    Mar 18 at 20:25







  • 3




    $begingroup$
    @jpmc26 That's a solid principle,.. I will use this in future code reviews :)
    $endgroup$
    – Ludisposed
    Mar 18 at 20:36












Your Answer





StackExchange.ifUsing("editor", function ()
return StackExchange.using("mathjaxEditing", function ()
StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix)
StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["\$", "\$"]]);
);
);
, "mathjax-editing");

StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");

StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "196"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);

else
createEditor();

);

function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);



);













draft saved

draft discarded


















StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f215662%2fhackerrank-all-womens-codesprint-2019-name-the-product%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes









15












$begingroup$

Imports



import math, os, random, re, sys
from collections import defaultdict as dd, Counter as count


Seriously, don't do this. It may be useful to read PEP8 regarding imports again.



  • Imports should be on separate lines.


  • Why do Counter as count? It impairs readability.



    Especially in larger scripts, every Python dev knows Counter, but count could be a random variable and is easy to be overshadowed.



  • You don't use all of the imported modules; just remove them if you don't need them.



  • alphabet = "abcdefghijklmnopqrstuvwxyz"


    Here you missed something that is in the standard lib: from string import ascii_lowercase



Misc




  • This dd(lambda: 0, ... adds no value



    Counter is already a dictionary with default value 0 just remove that part




  • Magic numbers



    5 is a Magic number, you should define it as a CONSTANT:



    NAME_LENGTH = 5


The rest looks good!






share|improve this answer











$endgroup$








  • 6




    $begingroup$
    May as well avoid aliasing defaultdict, too. Who the heck is going to know what dd is if they skip past the imports?
    $endgroup$
    – jpmc26
    Mar 18 at 18:28










  • $begingroup$
    They're fault for skipping past the imports IMO. shrugs
    $endgroup$
    – Tobi Alafin
    Mar 18 at 18:59






  • 5




    $begingroup$
    Respectfully no, the same advice goes for aliasing defaultdict. In this small example it doesn't matter, and it's easy to read, but when you are working on larger projects this can be a true pain in the ***
    $endgroup$
    – Ludisposed
    Mar 18 at 19:03






  • 6




    $begingroup$
    @TobiAlafin You need to learn the Principle of Least Astonishment. The biggest thing you should do to make your code readable and maintainable is to avoid doing things that are surprising. Aliasing something that's referenced exactly once is the code is weird. It's surprising. So is abbreviating names from the standard library. Don't do things that will surprise other developers. Do normal things. Great code is so obvious, it makes you think you could have easily thought of it.
    $endgroup$
    – jpmc26
    Mar 18 at 20:25







  • 3




    $begingroup$
    @jpmc26 That's a solid principle,.. I will use this in future code reviews :)
    $endgroup$
    – Ludisposed
    Mar 18 at 20:36
















15












$begingroup$

Imports



import math, os, random, re, sys
from collections import defaultdict as dd, Counter as count


Seriously, don't do this. It may be useful to read PEP8 regarding imports again.



  • Imports should be on separate lines.


  • Why do Counter as count? It impairs readability.



    Especially in larger scripts, every Python dev knows Counter, but count could be a random variable and is easy to be overshadowed.



  • You don't use all of the imported modules; just remove them if you don't need them.



  • alphabet = "abcdefghijklmnopqrstuvwxyz"


    Here you missed something that is in the standard lib: from string import ascii_lowercase



Misc




  • This dd(lambda: 0, ... adds no value



    Counter is already a dictionary with default value 0 just remove that part




  • Magic numbers



    5 is a Magic number, you should define it as a CONSTANT:



    NAME_LENGTH = 5


The rest looks good!






share|improve this answer











$endgroup$








  • 6




    $begingroup$
    May as well avoid aliasing defaultdict, too. Who the heck is going to know what dd is if they skip past the imports?
    $endgroup$
    – jpmc26
    Mar 18 at 18:28










  • $begingroup$
    They're fault for skipping past the imports IMO. shrugs
    $endgroup$
    – Tobi Alafin
    Mar 18 at 18:59






  • 5




    $begingroup$
    Respectfully no, the same advice goes for aliasing defaultdict. In this small example it doesn't matter, and it's easy to read, but when you are working on larger projects this can be a true pain in the ***
    $endgroup$
    – Ludisposed
    Mar 18 at 19:03






  • 6




    $begingroup$
    @TobiAlafin You need to learn the Principle of Least Astonishment. The biggest thing you should do to make your code readable and maintainable is to avoid doing things that are surprising. Aliasing something that's referenced exactly once is the code is weird. It's surprising. So is abbreviating names from the standard library. Don't do things that will surprise other developers. Do normal things. Great code is so obvious, it makes you think you could have easily thought of it.
    $endgroup$
    – jpmc26
    Mar 18 at 20:25







  • 3




    $begingroup$
    @jpmc26 That's a solid principle,.. I will use this in future code reviews :)
    $endgroup$
    – Ludisposed
    Mar 18 at 20:36














15












15








15





$begingroup$

Imports



import math, os, random, re, sys
from collections import defaultdict as dd, Counter as count


Seriously, don't do this. It may be useful to read PEP8 regarding imports again.



  • Imports should be on separate lines.


  • Why do Counter as count? It impairs readability.



    Especially in larger scripts, every Python dev knows Counter, but count could be a random variable and is easy to be overshadowed.



  • You don't use all of the imported modules; just remove them if you don't need them.



  • alphabet = "abcdefghijklmnopqrstuvwxyz"


    Here you missed something that is in the standard lib: from string import ascii_lowercase



Misc




  • This dd(lambda: 0, ... adds no value



    Counter is already a dictionary with default value 0 just remove that part




  • Magic numbers



    5 is a Magic number, you should define it as a CONSTANT:



    NAME_LENGTH = 5


The rest looks good!






share|improve this answer











$endgroup$



Imports



import math, os, random, re, sys
from collections import defaultdict as dd, Counter as count


Seriously, don't do this. It may be useful to read PEP8 regarding imports again.



  • Imports should be on separate lines.


  • Why do Counter as count? It impairs readability.



    Especially in larger scripts, every Python dev knows Counter, but count could be a random variable and is easy to be overshadowed.



  • You don't use all of the imported modules; just remove them if you don't need them.



  • alphabet = "abcdefghijklmnopqrstuvwxyz"


    Here you missed something that is in the standard lib: from string import ascii_lowercase



Misc




  • This dd(lambda: 0, ... adds no value



    Counter is already a dictionary with default value 0 just remove that part




  • Magic numbers



    5 is a Magic number, you should define it as a CONSTANT:



    NAME_LENGTH = 5


The rest looks good!







share|improve this answer














share|improve this answer



share|improve this answer








edited Mar 18 at 11:55









Toby Speight

26.8k742118




26.8k742118










answered Mar 18 at 11:15









LudisposedLudisposed

9,10322267




9,10322267







  • 6




    $begingroup$
    May as well avoid aliasing defaultdict, too. Who the heck is going to know what dd is if they skip past the imports?
    $endgroup$
    – jpmc26
    Mar 18 at 18:28










  • $begingroup$
    They're fault for skipping past the imports IMO. shrugs
    $endgroup$
    – Tobi Alafin
    Mar 18 at 18:59






  • 5




    $begingroup$
    Respectfully no, the same advice goes for aliasing defaultdict. In this small example it doesn't matter, and it's easy to read, but when you are working on larger projects this can be a true pain in the ***
    $endgroup$
    – Ludisposed
    Mar 18 at 19:03






  • 6




    $begingroup$
    @TobiAlafin You need to learn the Principle of Least Astonishment. The biggest thing you should do to make your code readable and maintainable is to avoid doing things that are surprising. Aliasing something that's referenced exactly once is the code is weird. It's surprising. So is abbreviating names from the standard library. Don't do things that will surprise other developers. Do normal things. Great code is so obvious, it makes you think you could have easily thought of it.
    $endgroup$
    – jpmc26
    Mar 18 at 20:25







  • 3




    $begingroup$
    @jpmc26 That's a solid principle,.. I will use this in future code reviews :)
    $endgroup$
    – Ludisposed
    Mar 18 at 20:36













  • 6




    $begingroup$
    May as well avoid aliasing defaultdict, too. Who the heck is going to know what dd is if they skip past the imports?
    $endgroup$
    – jpmc26
    Mar 18 at 18:28










  • $begingroup$
    They're fault for skipping past the imports IMO. shrugs
    $endgroup$
    – Tobi Alafin
    Mar 18 at 18:59






  • 5




    $begingroup$
    Respectfully no, the same advice goes for aliasing defaultdict. In this small example it doesn't matter, and it's easy to read, but when you are working on larger projects this can be a true pain in the ***
    $endgroup$
    – Ludisposed
    Mar 18 at 19:03






  • 6




    $begingroup$
    @TobiAlafin You need to learn the Principle of Least Astonishment. The biggest thing you should do to make your code readable and maintainable is to avoid doing things that are surprising. Aliasing something that's referenced exactly once is the code is weird. It's surprising. So is abbreviating names from the standard library. Don't do things that will surprise other developers. Do normal things. Great code is so obvious, it makes you think you could have easily thought of it.
    $endgroup$
    – jpmc26
    Mar 18 at 20:25







  • 3




    $begingroup$
    @jpmc26 That's a solid principle,.. I will use this in future code reviews :)
    $endgroup$
    – Ludisposed
    Mar 18 at 20:36








6




6




$begingroup$
May as well avoid aliasing defaultdict, too. Who the heck is going to know what dd is if they skip past the imports?
$endgroup$
– jpmc26
Mar 18 at 18:28




$begingroup$
May as well avoid aliasing defaultdict, too. Who the heck is going to know what dd is if they skip past the imports?
$endgroup$
– jpmc26
Mar 18 at 18:28












$begingroup$
They're fault for skipping past the imports IMO. shrugs
$endgroup$
– Tobi Alafin
Mar 18 at 18:59




$begingroup$
They're fault for skipping past the imports IMO. shrugs
$endgroup$
– Tobi Alafin
Mar 18 at 18:59




5




5




$begingroup$
Respectfully no, the same advice goes for aliasing defaultdict. In this small example it doesn't matter, and it's easy to read, but when you are working on larger projects this can be a true pain in the ***
$endgroup$
– Ludisposed
Mar 18 at 19:03




$begingroup$
Respectfully no, the same advice goes for aliasing defaultdict. In this small example it doesn't matter, and it's easy to read, but when you are working on larger projects this can be a true pain in the ***
$endgroup$
– Ludisposed
Mar 18 at 19:03




6




6




$begingroup$
@TobiAlafin You need to learn the Principle of Least Astonishment. The biggest thing you should do to make your code readable and maintainable is to avoid doing things that are surprising. Aliasing something that's referenced exactly once is the code is weird. It's surprising. So is abbreviating names from the standard library. Don't do things that will surprise other developers. Do normal things. Great code is so obvious, it makes you think you could have easily thought of it.
$endgroup$
– jpmc26
Mar 18 at 20:25





$begingroup$
@TobiAlafin You need to learn the Principle of Least Astonishment. The biggest thing you should do to make your code readable and maintainable is to avoid doing things that are surprising. Aliasing something that's referenced exactly once is the code is weird. It's surprising. So is abbreviating names from the standard library. Don't do things that will surprise other developers. Do normal things. Great code is so obvious, it makes you think you could have easily thought of it.
$endgroup$
– jpmc26
Mar 18 at 20:25





3




3




$begingroup$
@jpmc26 That's a solid principle,.. I will use this in future code reviews :)
$endgroup$
– Ludisposed
Mar 18 at 20:36





$begingroup$
@jpmc26 That's a solid principle,.. I will use this in future code reviews :)
$endgroup$
– Ludisposed
Mar 18 at 20:36


















draft saved

draft discarded
















































Thanks for contributing an answer to Code Review Stack Exchange!


  • Please be sure to answer the question. Provide details and share your research!

But avoid


  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.

Use MathJax to format equations. MathJax reference.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f215662%2fhackerrank-all-womens-codesprint-2019-name-the-product%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Solar Wings Breeze Design and development Specifications (Breeze) References Navigation menu1368-485X"Hang glider: Breeze (Solar Wings)"e

Kathakali Contents Etymology and nomenclature History Repertoire Songs and musical instruments Traditional plays Styles: Sampradayam Training centers and awards Relationship to other dance forms See also Notes References External links Navigation menueThe Illustrated Encyclopedia of Hinduism: A-MSouth Asian Folklore: An EncyclopediaRoutledge International Encyclopedia of Women: Global Women's Issues and KnowledgeKathakali Dance-drama: Where Gods and Demons Come to PlayKathakali Dance-drama: Where Gods and Demons Come to PlayKathakali Dance-drama: Where Gods and Demons Come to Play10.1353/atj.2005.0004The Illustrated Encyclopedia of Hinduism: A-MEncyclopedia of HinduismKathakali Dance-drama: Where Gods and Demons Come to PlaySonic Liturgy: Ritual and Music in Hindu Tradition"The Mirror of Gesture"Kathakali Dance-drama: Where Gods and Demons Come to Play"Kathakali"Indian Theatre: Traditions of PerformanceIndian Theatre: Traditions of PerformanceIndian Theatre: Traditions of PerformanceIndian Theatre: Traditions of PerformanceMedieval Indian Literature: An AnthologyThe Oxford Companion to Indian TheatreSouth Asian Folklore: An Encyclopedia : Afghanistan, Bangladesh, India, Nepal, Pakistan, Sri LankaThe Rise of Performance Studies: Rethinking Richard Schechner's Broad SpectrumIndian Theatre: Traditions of PerformanceModern Asian Theatre and Performance 1900-2000Critical Theory and PerformanceBetween Theater and AnthropologyKathakali603847011Indian Theatre: Traditions of PerformanceIndian Theatre: Traditions of PerformanceIndian Theatre: Traditions of PerformanceBetween Theater and AnthropologyBetween Theater and AnthropologyNambeesan Smaraka AwardsArchivedThe Cambridge Guide to TheatreRoutledge International Encyclopedia of Women: Global Women's Issues and KnowledgeThe Garland Encyclopedia of World Music: South Asia : the Indian subcontinentThe Ethos of Noh: Actors and Their Art10.2307/1145740By Means of Performance: Intercultural Studies of Theatre and Ritual10.1017/s204912550000100xReconceiving the Renaissance: A Critical ReaderPerformance TheoryListening to Theatre: The Aural Dimension of Beijing Opera10.2307/1146013Kathakali: The Art of the Non-WorldlyOn KathakaliKathakali, the dance theatreThe Kathakali Complex: Performance & StructureKathakali Dance-Drama: Where Gods and Demons Come to Play10.1093/obo/9780195399318-0071Drama and Ritual of Early Hinduism"In the Shadow of Hollywood Orientalism: Authentic East Indian Dancing"10.1080/08949460490274013Sanskrit Play Production in Ancient IndiaIndian Music: History and StructureBharata, the Nāṭyaśāstra233639306Table of Contents2238067286469807Dance In Indian Painting10.2307/32047833204783Kathakali Dance-Theatre: A Visual Narrative of Sacred Indian MimeIndian Classical Dance: The Renaissance and BeyondKathakali: an indigenous art-form of Keralaeee

Method to test if a number is a perfect power? Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 23, 2019 at 00:00UTC (8:00pm US/Eastern)Detecting perfect squares faster than by extracting square rooteffective way to get the integer sequence A181392 from oeisA rarely mentioned fact about perfect powersHow many numbers such $n$ are there that $n<100,lfloorsqrtn rfloor mid n$Check perfect squareness by modulo division against multiple basesFor what pair of integers $(a,b)$ is $3^a + 7^b$ a perfect square.Do there exist any positive integers $n$ such that $lfloore^nrfloor$ is a perfect power? What is the probability that one exists?finding perfect power factors of an integerProve that the sequence contains a perfect square for any natural number $m $ in the domain of $f$ .Counting Perfect Powers