Javascript (E6) 92 96
Daha kısa ve uyumlu - stdin / stdout'u okumak için spidermonkey kabuğu kullanın (virgül ve boşluk ile). Benim 10000th çifti 1260989, 1260991 bilgisayarımda bir dakikanın altında bulur P yerine dizilebilmek
için kısa kullanmak p[n]=o=n
yerine p.push(o=n)
. Ama bu oldukça yavaş ve ben zaten kod uzunluğu için kazanamayacağım.
m=readline();for(n=3,o=p=[];m;n+=2)p.every(e=>n%e)&&(m-=n-o<3,p.push(o=n));print(o-2+', '+o)
Firefox konsolunda denemek için:
m=prompt();for(n=3,o=p=[];m;n+=2)p.every(e=>n%e)&&(m-=n-o<3,p.push(o=n));alert(o-2+', '+o)
Ungolfed
Tüm ilk m ikizlerini bulan işlev (en büyük değeri döndürür):
T=m=>{
for (o=n=3, p=[2], t=[]; !t[m-1]; n+=2)
p.every(e => n%e) && (n-o-2 ? 0 : t.push(n), p.push(o=n))
return t
}
Örnek: console.log(T(50))
[5, 7, 13, 19, 31, 43, 61, 73, 103, 109, 139, 151, 181, 193, 199, 229, 241, 271, 283, 313, 349, 421, 433, 463, 523, 571, 601, 619, 643, 661, 811, 823, 829, 859, 883, 1021, 1033, 1051, 1063, 1093, 1153, 1231, 1279, 1291, 1303, 1321, 1429, 1453, 1483, 1489]
Sadece sonuncusu:
L=m=>{
for (o=n=3,p=[2]; m; n+=2)
p.every(e => n%e) && (m -= n-o==2, p.push(o=n))
return o
}
Ardından bu 2 satırı alın ve IO ekleyin
m = prompt()
for (o=n=3, p=[2]; m; n+=2)
p.every(e => n%e) && (m -= n-o==2, p.push(o=n))
alert('o-2+', '+o)