{ "cells": [ { "cell_type": "code", "execution_count": 2, "metadata": { "collapsed": false }, "outputs": [], "source": [ "import itertools" ] }, { "cell_type": "code", "execution_count": 12, "metadata": { "collapsed": false }, "outputs": [ { "data": { "text/plain": [ "[(1, [1, 1]), (2, [2, 2, 2]), (1, [1, 1]), (3, [3])]" ] }, "execution_count": 12, "metadata": {}, "output_type": "execute_result" } ], "source": [ "[(i, list(ii)) for i, ii in itertools.groupby([1,1,2,2,2,1,1,3])]" ] }, { "cell_type": "code", "execution_count": 22, "metadata": { "collapsed": true }, "outputs": [], "source": [ "def chunks(sequence):\n", " return [(len(list(ii)), i) for i, ii in itertools.groupby(int(d) for d in sequence)]" ] }, { "cell_type": "code", "execution_count": 23, "metadata": { "collapsed": false }, "outputs": [ { "data": { "text/plain": [ "[(3, 1), (2, 2), (1, 1)]" ] }, "execution_count": 23, "metadata": {}, "output_type": "execute_result" } ], "source": [ "chunks('111221')" ] }, { "cell_type": "code", "execution_count": 24, "metadata": { "collapsed": true }, "outputs": [], "source": [ "def looksay(chunks):\n", " return ''.join(str(item) for chunk in chunks for item in chunk)" ] }, { "cell_type": "code", "execution_count": 25, "metadata": { "collapsed": false }, "outputs": [ { "data": { "text/plain": [ "'312211'" ] }, "execution_count": 25, "metadata": {}, "output_type": "execute_result" } ], "source": [ "looksay(chunks('111221'))" ] }, { "cell_type": "code", "execution_count": 26, "metadata": { "collapsed": false }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "11\n", "21\n", "1211\n", "111221\n", "312211\n", "13112221\n", "1113213211\n", "31131211131221\n", "13211311123113112211\n", "11131221133112132113212221\n" ] } ], "source": [ "lss = '1'\n", "for i in range(10):\n", " lss = looksay(chunks(lss))\n", " print(lss)" ] }, { "cell_type": "code", "execution_count": 27, "metadata": { "collapsed": false }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "329356\n" ] } ], "source": [ "lss = '3113322113'\n", "for _ in range(40):\n", " lss = looksay(chunks(lss))\n", "print(len(lss))" ] }, { "cell_type": "code", "execution_count": 28, "metadata": { "collapsed": false }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "4666278\n" ] } ], "source": [ "lss = '3113322113'\n", "for _ in range(50):\n", " lss = looksay(chunks(lss))\n", "print(len(lss))" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": true }, "outputs": [], "source": [] } ], "metadata": { "kernelspec": { "display_name": "Python 3", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.4.3" } }, "nbformat": 4, "nbformat_minor": 0 }