unofficial mirror of help-gnu-emacs@gnu.org
 help / color / mirror / Atom feed
From: Hongyi Zhao <hongyi.zhao@gmail.com>
To: help-gnu-emacs <help-gnu-emacs@gnu.org>
Subject: Re: Search through the string's space for find the target string whose md5sum matches the required condition.
Date: Tue, 12 Oct 2021 19:47:29 +0800	[thread overview]
Message-ID: <CAGP6POJSej8p2nFnrQC+PdaAFxKerW3S=b5rGw2GMNqqy5wiDg@mail.gmail.com> (raw)
In-Reply-To: <CAGP6PO+sQCd4zc78ix7Pu0Ljc0bOhu2a8VOP8YfnpPPSGMRHig@mail.gmail.com>

On Tue, Oct 12, 2021 at 4:42 PM Hongyi Zhao <hongyi.zhao@gmail.com> wrote:
>
> Suppose we have a string represented as follows, where `?' represents
> arbitrary uppercase letters:
>
> TASC?O3RJMV?WDJKX?ZM
>
> We also know that its md5sum has the following form:
>
> E903???4DAB????08?????51?80??8A?
>
> Based on the above information, find out the string and its
> corresponding md5sum.
>
> I've done the work with the following python code:
>
> ```python
> import re
> from hashlib import md5
> from string import ascii_uppercase
>
> alphabet_uppercase=ascii_uppercase
> re_md5_str=re.compile(r'^E903[A-F0-9]{3}4DAB[A-F0-9]{4}08[A-F0-9]{5}51[A-F0-9]80[A-F0-9]{2}8A[A-F0-9]')
>
> #result_str=[]
> for i in alphabet_uppercase:
>     i_str= 'TASC' + i
>     for j in alphabet_uppercase:
>         j_str = i_str + 'O3RJMV' + j
>         for k in alphabet_uppercase:
>             k_str = j_str + 'WDJKX' + k + 'ZM'
>             #result_str.append(k_str)
>             md5_str=md5(k_str.encode('utf-8')).hexdigest().upper()
>             if re_md5_str.match(md5_str):
>                 md5_str = re_md5_str.match(md5_str)[0]
>                 print('The string: ' + k_str + '\n' + 'md5sum: ' + md5_str)
> ```

The following is an improved version:

```python
import re
from hashlib import md5
from string import ascii_uppercase

alphabet_uppercase = ascii_uppercase
re_md5_str = re.compile(r"""^E903[A-F0-9]{3}
                4DAB[A-F0-9]{4}
                08[A-F0-9]{5}
                51[A-F0-9]
                80[A-F0-9]{2}
                8A[A-F0-9]""", re.X)

for i in alphabet_uppercase:
    i_str = 'TASC' + i
    for j in alphabet_uppercase:
        j_str = i_str + 'O3RJMV' + j
        for k in alphabet_uppercase:
            _str = j_str + 'WDJKX' + k + 'ZM'
            md5_str = md5(_str.encode('utf-8')).hexdigest().upper()
            if re_md5_str.match(md5_str):
                print('string: ' + _str + '\n' + 'md5sum: ' + md5_str)
```
HZ



  parent reply	other threads:[~2021-10-12 11:47 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-10-12  8:42 Search through the string's space for find the target string whose md5sum matches the required condition Hongyi Zhao
2021-10-12  9:39 ` Emanuel Berg via Users list for the GNU Emacs text editor
2021-10-12 11:45   ` Hongyi Zhao
2021-10-12 13:01     ` Emanuel Berg via Users list for the GNU Emacs text editor
2021-10-12 11:47 ` Hongyi Zhao [this message]
2021-10-12 13:06   ` Emanuel Berg via Users list for the GNU Emacs text editor
2021-10-13  2:29     ` Hongyi Zhao
2021-10-13 23:14       ` Emanuel Berg via Users list for the GNU Emacs text editor
2021-10-15  4:36         ` Hongyi Zhao
2021-10-15  7:19           ` Emanuel Berg via Users list for the GNU Emacs text editor

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://www.gnu.org/software/emacs/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to='CAGP6POJSej8p2nFnrQC+PdaAFxKerW3S=b5rGw2GMNqqy5wiDg@mail.gmail.com' \
    --to=hongyi.zhao@gmail.com \
    --cc=help-gnu-emacs@gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).