Skip to content

Instantly share code, notes, and snippets.

@butchi
Created October 11, 2022 14:58
Show Gist options
  • Save butchi/ffb5c6de3d01aae2d57faa40054dfef4 to your computer and use it in GitHub Desktop.
Save butchi/ffb5c6de3d01aae2d57faa40054dfef4 to your computer and use it in GitHub Desktop.
"素数大富豪って直感的にかなりの確率で初手全部出しできる気がするんだけどどうなんだろう?" に対する解答
Display the source blob
Display the rendered blob
Raw
{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"[素数大富豪って直感的にかなりの確率で初手全部出しできる気がするんだけどどうなんだろう?](https://twitter.com/coilgun_9/status/1579131945836953601)\n",
"に対する解答"
]
},
{
"cell_type": "code",
"execution_count": 1,
"metadata": {
"vscode": {
"languageId": "wolfram"
}
},
"outputs": [],
"source": [
"(* 再現性のためシードを固定 *)\n",
"SeedRandom[0];"
]
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {
"vscode": {
"languageId": "wolfram"
}
},
"outputs": [
{
"data": {
"text/html": [
"<div><pre style=\"&#102;&#111;&#110;&#116;&#45;&#102;&#97;&#109;&#105;&#108;&#121;&#58;&#32;&#34;&#67;&#111;&#117;&#114;&#105;&#101;&#114;&#32;&#78;&#101;&#119;&#34;&#44;&#67;&#111;&#117;&#114;&#105;&#101;&#114;&#44;&#109;&#111;&#110;&#111;&#115;&#112;&#97;&#99;&#101;&#59;\">&#123;&#49;&#44;&#32;&#49;&#44;&#32;&#49;&#44;&#32;&#49;&#44;&#32;&#50;&#44;&#32;&#50;&#44;&#32;&#50;&#44;&#32;&#50;&#44;&#32;&#51;&#44;&#32;&#51;&#44;&#32;&#51;&#44;&#32;&#51;&#44;&#32;&#52;&#44;&#32;&#52;&#44;&#32;&#52;&#44;&#32;&#52;&#44;&#32;&#53;&#44;&#32;&#53;&#44;&#32;&#53;&#44;&#32;&#53;&#44;&#32;&#54;&#44;&#32;&#54;&#44;&#32;&#54;&#44;&#32;&#54;&#44;&#32;&#55;&#44;&#32;&#55;&#44;&#32;&#55;&#44;&#32;&#55;&#44;&#32;&#56;&#44;&#32;&#10;&#32;&#10;&#62;&#32;&#32;&#32;&#56;&#44;&#32;&#56;&#44;&#32;&#56;&#44;&#32;&#57;&#44;&#32;&#57;&#44;&#32;&#57;&#44;&#32;&#57;&#44;&#32;&#49;&#48;&#44;&#32;&#49;&#48;&#44;&#32;&#49;&#48;&#44;&#32;&#49;&#48;&#44;&#32;&#49;&#49;&#44;&#32;&#49;&#49;&#44;&#32;&#49;&#49;&#44;&#32;&#49;&#49;&#44;&#32;&#49;&#50;&#44;&#32;&#49;&#50;&#44;&#32;&#49;&#50;&#44;&#32;&#49;&#50;&#44;&#32;&#49;&#51;&#44;&#32;&#49;&#51;&#44;&#32;&#49;&#51;&#44;&#32;&#49;&#51;&#125;</pre></div>"
],
"text/plain": [
"{1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 6, 6, 6, 6, 7, 7, 7, 7, 8, \n",
" \n",
"> 8, 8, 8, 9, 9, 9, 9, 10, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 13, 13, 13, 13}"
]
},
"execution_count": 4,
"metadata": {
"text/html": [],
"text/plain": []
},
"output_type": "execute_result"
}
],
"source": [
"(* デッキ ジョーカーは除く *)\n",
"deck = Sort[Join @@ Table[Range[13], 4]]"
]
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {
"vscode": {
"languageId": "wolfram"
}
},
"outputs": [],
"source": [
"(* 手札listを数値化する関数 *)\n",
"handToInteger[li_] := FromDigits[StringJoin @@ (ToString /@ li)]"
]
},
{
"cell_type": "code",
"execution_count": 7,
"metadata": {
"vscode": {
"languageId": "wolfram"
}
},
"outputs": [],
"source": [
"(* cLen枚のカードをデッキからランダムに引く関数 *)\n",
"randomHand[cLen_: 11] := RandomSample[deck, cLen]"
]
},
{
"cell_type": "code",
"execution_count": 10,
"metadata": {
"vscode": {
"languageId": "wolfram"
}
},
"outputs": [
{
"data": {
"text/html": [
"<div><pre style=\"&#102;&#111;&#110;&#116;&#45;&#102;&#97;&#109;&#105;&#108;&#121;&#58;&#32;&#34;&#67;&#111;&#117;&#114;&#105;&#101;&#114;&#32;&#78;&#101;&#119;&#34;&#44;&#67;&#111;&#117;&#114;&#105;&#101;&#114;&#44;&#109;&#111;&#110;&#111;&#115;&#112;&#97;&#99;&#101;&#59;\">&#123;&#56;&#44;&#32;&#49;&#44;&#32;&#52;&#44;&#32;&#49;&#51;&#44;&#32;&#51;&#44;&#32;&#49;&#49;&#44;&#32;&#49;&#50;&#44;&#32;&#49;&#49;&#44;&#32;&#49;&#51;&#44;&#32;&#53;&#44;&#32;&#49;&#49;&#125;</pre></div>"
],
"text/plain": [
"{8, 1, 4, 13, 3, 11, 12, 11, 13, 5, 11}"
]
},
"execution_count": 10,
"metadata": {
"text/html": [],
"text/plain": []
},
"output_type": "execute_result"
}
],
"source": [
"(* 試しに11枚引いてみる *)\n",
"randomHand[11]"
]
},
{
"cell_type": "code",
"execution_count": 11,
"metadata": {
"vscode": {
"languageId": "wolfram"
}
},
"outputs": [],
"source": [
"(* 手札をランダムにシャッフルする関数 *)\n",
"shuffleHand[li_] := RandomSample[li, Length[li]]\n",
"\n",
"(* (* 全部試すなら以下のコードを使える *) *)\n",
"(* shuffleHandList[li_] := Permutations[li] *)"
]
},
{
"cell_type": "code",
"execution_count": 18,
"metadata": {
"vscode": {
"languageId": "wolfram"
}
},
"outputs": [
{
"data": {
"text/html": [
"<div><img alt=\"Output\" src=\"\"></div>"
],
"text/plain": [
"{{10, 2, 1, 4, 6, 7, 5, 11, 13, 11, 3}, <<664>>, {6, 5, 8, <<7>>, 5}}"
]
},
"execution_count": 18,
"metadata": {
"text/html": [],
"text/plain": []
},
"output_type": "execute_result"
}
],
"source": [
"(* 十分大きな回数ランダムにhandのリストを作り、3の倍数チェックをパスする手札のみ抽出 *)\n",
"handLi = Table[randomHand[11], 999];\n",
"handLiPass3Check = Select[handLi, !Divisible[handToInteger[#], 3] &];\n",
"handLiPass3Check // Short"
]
},
{
"cell_type": "code",
"execution_count": 21,
"metadata": {
"vscode": {
"languageId": "wolfram"
}
},
"outputs": [
{
"data": {
"text/html": [
"<div><img alt=\"Output\" src=\"\"></div>"
],
"text/plain": [
"{{8, 12, 4, 13, 7, 3, 5, 3, 4, 3, 6}, <<48>>, {10, 10, 8, <<7>>, 2}}"
]
},
"execution_count": 21,
"metadata": {
"text/html": [],
"text/plain": []
},
"output_type": "execute_result"
}
],
"source": [
"(* 手札を適当にシャッフルして素数になったものだけを抽出 *)\n",
"handRandomPrimeLi = Select[\n",
" handLiPass3Check,\n",
" PrimeQ[handToInteger[shuffleHand[#]]] &\n",
"];\n",
"Short[handRandomPrimeLi]"
]
},
{
"cell_type": "code",
"execution_count": 23,
"metadata": {
"vscode": {
"languageId": "wolfram"
}
},
"outputs": [
{
"data": {
"text/html": [
"<div><img alt=\"Output\" src=\"\"></div>"
],
"text/plain": [
"7.508%"
]
},
"execution_count": 23,
"metadata": {
"text/html": [],
"text/plain": []
},
"output_type": "execute_result"
}
],
"source": [
"(* 3倍チェックだけして適当に出した全出しが素数になる確率 *)\n",
"PercentForm[N[Length[handRandomPrimeLi] / Length[handLiPass3Check]]]"
]
},
{
"cell_type": "code",
"execution_count": 26,
"metadata": {
"vscode": {
"languageId": "wolfram"
}
},
"outputs": [
{
"data": {
"text/html": [
"<div><img alt=\"Output\" src=\"\"></div>"
],
"text/plain": [
"{{10, 2, 1, 4, 6, 7, 5, 11, 13, 11, 3}, <<656>>, {6, 5, 8, <<7>>, 5}}"
]
},
"execution_count": 26,
"metadata": {
"text/html": [],
"text/plain": []
},
"output_type": "execute_result"
}
],
"source": [
"(* 手札を十分大きな回数シャッフルしていずれかが素数になるものだけを抽出 *)\n",
"handIncludePrimeLi = Select[\n",
" handLiPass3Check,\n",
" AnyTrue[\n",
" Table[shuffleHand[#], 99], \n",
" PrimeQ[handToInteger[#]] &\n",
" ] &\n",
"];\n",
"Short[handIncludePrimeLi]\n"
]
},
{
"cell_type": "code",
"execution_count": 28,
"metadata": {
"vscode": {
"languageId": "wolfram"
}
},
"outputs": [
{
"data": {
"text/html": [
"<div><img alt=\"Output\" src=\"\"></div>"
],
"text/plain": [
"98.8%"
]
},
"execution_count": 28,
"metadata": {
"text/html": [],
"text/plain": []
},
"output_type": "execute_result"
}
],
"source": [
"(* 3倍チェックだけして全出しが素数になる確率(概算) *)\n",
"PercentForm[N[Length[handIncludePrimeLi] / Length[handLiPass3Check]]]"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"vscode": {
"languageId": "wolfram"
}
},
"outputs": [],
"source": []
}
],
"metadata": {
"kernelspec": {
"display_name": "Wolfram Language 13.1",
"language": "Wolfram Language",
"name": "wolframlanguage13.1"
},
"language_info": {
"codemirror_mode": "mathematica",
"file_extension": ".m",
"mimetype": "application/vnd.wolfram.m",
"name": "Wolfram Language",
"pygments_lexer": "mathematica",
"version": "12.0"
},
"orig_nbformat": 4
},
"nbformat": 4,
"nbformat_minor": 2
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment