On 03/07/2020 11:09, Daley Okuwa via Python-list wrote:

Please can someone help

Write an algorithm (choose the language you prefer) that given a character 
string, for instance {‘c’,’a’,’i’,’o’,’p’,’a’}, will print out the list of 
characters appearing at least 2 times. In this specific example, it would 
return {‘a’}. Afterwards, comment out the cost in terms of space and time.

The first thing to do with any problem is to break it down into bits. In the case of Python, writing them out as "pseudo-code" instructions often helps. In this case you have:

Set up something to count letters with
For each letter in the string:
    If we haven't seen this letter before:
        Set the counter for the letter to 1
    Else:
        Add 1 to the counter for the letter

For each counter:
    If the count is 2 or more:
        Print the letter

Now there are a lot of possible ways to write that, but they mostly come down to deciding what data structure to use to count letters with. Have a browse through a tutorial (or the standard library if you are feeling adventurous) and see what you think might work, then try it.

Write a bash/python script that takes a directory as an argument and output the 
total lines of code in *.cpp files recursively.

In bash, what existing commands count things? If you don't know, how might you find out? Then you have to figure out how to do that for each *.cpp file in a directory, and add the totals together.

In Python, you can read a file one line at a time, so how to count the number of lines in a file should be pretty obvious. Figuring out how to do that for every *.cpp file in a directory will involve looking through the standard library, or getting a bash script to do it for you :-)

--
Rhodri James *-* Kynesim Ltd
--
https://mail.python.org/mailman/listinfo/python-list

Reply via email to