diff options
| author | Mohammad S Anwar <Mohammad.Anwar@yahoo.com> | 2020-08-23 09:04:17 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-08-23 09:04:17 +0100 |
| commit | bb7fd02e8f49a66946a48b8bd5c60d01ab5a86c9 (patch) | |
| tree | 5cc258a2dd908f795f83cabc41283f83bf5b90b3 /challenge-074/lubos-kolouch/python/ch_2.py | |
| parent | 72c8355c9d6aaba5af6e323ca8e6d5c5d60a3f1c (diff) | |
| parent | fc350103aee950ecd6ae058c985e9f3e94710e2b (diff) | |
| download | perlweeklychallenge-club-bb7fd02e8f49a66946a48b8bd5c60d01ab5a86c9.tar.gz perlweeklychallenge-club-bb7fd02e8f49a66946a48b8bd5c60d01ab5a86c9.tar.bz2 perlweeklychallenge-club-bb7fd02e8f49a66946a48b8bd5c60d01ab5a86c9.zip | |
Merge pull request #2118 from LubosKolouch/chal_074_LK
Solutions 074 LK Python
Diffstat (limited to 'challenge-074/lubos-kolouch/python/ch_2.py')
| -rw-r--r-- | challenge-074/lubos-kolouch/python/ch_2.py | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/challenge-074/lubos-kolouch/python/ch_2.py b/challenge-074/lubos-kolouch/python/ch_2.py new file mode 100644 index 0000000000..da21ecc6fb --- /dev/null +++ b/challenge-074/lubos-kolouch/python/ch_2.py @@ -0,0 +1,43 @@ +#!/usr/bin/env python +""" FNR character from Perl weekly challenge 074 task 2 """ + + +# =============================================================================== +# +# FILE: ch-_.py +# +# USAGE: ./ch_2.py +# +# DESCRIPTION: https://perlweeklychallenge.org/blog/perl-weekly-challenge-074/ +# +# TASK #2 › FNR Character +# +# AUTHOR: Lubos Kolouch +# VERSION: 1.0 +# CREATED: 08/22/2020 12:40:09 PM +# =============================================================================== + + +def get_fnr(in_str): + """ Find and return the FNR in the given string """ + + fnr_count = dict() + fnr_queue = list() + + result = '' + + for char in in_str: + fnr_count[char] = fnr_count.get(char, 0) + 1 + + if fnr_count[char] == 1: + fnr_queue.append(char) + else: + fnr_queue.remove(char) + + result += fnr_queue[-1] if fnr_queue else '#' + + return result + + +assert get_fnr('ababc') == 'abb#c' +assert get_fnr('xyzzyx') == 'xyzyx#' |
