कौन सी भाषा सबसे छोटी है?


25

एक प्रोग्राम बनाएं जो -टैग के साथ नवीनतम 50 चुनौतियों का पता लगाएं, जिसमें कम से कम 20 उत्तर हों। फिर, प्रत्येक भाषा में प्रत्येक चुनौतियों के लिए स्कोर निकालें। यदि एक ही भाषा का उपयोग करते हुए एक से अधिक उत्तर हैं, तो सभी अंकों की गणना करें। इसके बाद, शीर्ष 20 सबसे आम भाषाओं को लें और भाषा के नामों के साथ एक सूची का उत्पादन करें, उत्तरों की संख्या, औसत बाइट मायने रखता है और माध्य बाइट मायने रखता है। सूची को अवरोही क्रम में, उत्तरों की संख्या द्वारा क्रमबद्ध किया जाना चाहिए।

आपको कैपिटलाइज़ेशन में बदलाव के लिए खाता होना चाहिए (उदाहरण के लिए: Matlab = MATLAB)।

कई अलग-अलग संस्करण संख्या वाली भाषाओं में (जैसे पायथन), उन्हें अद्वितीय भाषाओं के रूप में गिना जाता है, इसलिए: Python != Python 2 != Python 2.7 != Python 3.x

उदाहरण आउटपुट (आउटपुट स्वरूप वैकल्पिक है):

cJam,       66,  12.4,  8.5
Pyth,       58,   15.2,  19
Ruby,       44,   19.2,  22.5
Python,     34,   29.3,  32
Python 2.7, 22,   31.2,  40
...
...
Java,       11,   115.5, 94.5

हैडर प्रारूप जो समर्थित होने चाहिए:

  • इसके साथ आरंभ होता है # Language name, या#Language name
  • इसी के साथ समाप्त होता है xx bytes , xx Bytesया बसxx
  • पहले अल्पविराम और अंतिम संख्या के बीच बहुत अधिक कचरा हो सकता है।
  • यदि भाषा का नाम एक लिंक ( [Name](link)) है, तो इसे छोड़ दिया जा सकता है

यदि उत्तर में एक और हेडर प्रारूप है, तो आप इसे छोड़ सकते हैं (या इसे शामिल कर सकते हैं यदि आपका कोड इसे संभाल सकता है)।

एक उदाहरण के रूप में, नीचे दिए गए सभी शीर्षकों का समर्थन किया जाना चाहिए:

# Language Name, N bytes
# Ruby, <s>104</s> <s>101</s> 96 bytes 
# Perl, 43 + 2 (-p flag) = 45 Bytes
# MATLAB, 5

नियम:

  • एपीआई या सिर्फ वेबसाइट-यूआरएल का उपयोग करना ठीक है
    • निम्नलिखित को बाइट काउंट (और कुछ नहीं) से निकाला जा सकता है, इसलिए url-shortener (अधिकतम 44 बाइट) का उपयोग करने की आवश्यकता नहीं है:
      • https://(या http://)
      • codegolf
      • .stackexchange.com
      • /questions
  • कार्यक्रम इनपुट ले सकता है। इनपुट को बाइट काउंट में शामिल किया जाएगा।

इसके अलावा, मानक नियम लागू होते हैं।


11
मैं आपको बता सकता हूँ कि यह इस चुनौती को करने के लिए बिना पायथ है।
एलेक्स ए।

1
"बाइट्स" प्रत्यय सामान्य है, अकेले को सार्वभौमिक, इसकी आवश्यकता के लिए पर्याप्त है?
शुक्राणु

@StewieGriffin मुझे लगता है कि Sparr यह कह रहा है, जबकि यह आम है , यह हमेशा उपयोग नहीं किया जाता है।
सेलेओ

जहाँ तक मैं देख सकता हूँ, xx bytesहाल की चुनौतियों पर बहुत कम है (कम से कम जब से लीडरबोर्ड स्निपेट बनाया गया था)।
स्टिव ग्रिफिन

2
मैं आमतौर पर "बाइट्स" के बजाय "वर्ण" या "वर्ण" का उपयोग करता हूं
दरवाज़े

जवाबों:


13

आर, 821 - 44 = 777 बाइट्स

अपडेट किए गए परिणाम : नीचे दिए गए सभी टिप्पणियों की समझ बनाने के लिए कृपया संपादन इतिहास देखें।

           language num_answers avg_count median_count
1              RUBY          49  49.97959         30.0
2              CJAM          48  32.64583         22.0
3              PYTH          48  21.02083         14.0
4          PYTHON 2          46  86.78261         77.0
5             JULIA          43  58.90698         45.0
6           HASKELL          41  74.65854         56.0
7               PHP          40  73.52500         48.0
8              PERL          36  53.30556         34.0
9          PYTHON 3          34  90.91176         90.5
10       POWERSHELL          33  60.24242         44.0
11                C          32 221.84375         79.5
12                R          32  77.40625         62.5
13             JAVA          29 170.68966        158.0
14 JAVASCRIPT (ES6)          29  90.79310         83.0
15       JAVASCRIPT          28  68.39286         61.0
16               C#          25 193.92000        130.0
17      MATHEMATICA          23  56.04348         47.0
18           MATLAB          22  67.45455         55.0
19         TI-BASIC          19  47.05263         37.0
20              APL          18  16.55556         15.0

कोड, जिसे मैं थोड़ा और छोटा कर सकता था:

W=library;W(XML);W(plyr)
X=xpathSApply;Y=xmlValue;D=data.frame;H=htmlParse;S=sprintf
Z="http://codegolf.stackexchange.com/"
R=function(FUN,...)do.call(rbind,Map(FUN,...))
G=function(url){d=H(url)
a=as.double(sub(".*?(\\d+)a.*","\\1",X(d,"//div[starts-with(@class,'status')]",Y)))
u=paste0(Z,X(d,"//*[contains(@class,'question-hyperlink')]",xmlGetAttr,"href"))
D(u,a)}
u=S("%s/questions/tagged/code-golf?page=%i",Z,1:50)
q=R(G,u)
u=with(q,head(u[a>20],50))
A=function(url){u=S("%s?page=%i",url,1:10)
f=function(u){d=H(u)
h=X(d, "//div[@class='post-text']//h1",Y)
p="^(.*?),.*? (\\d+)( [Bb]ytes)?$"
k=grep(p,h,v=T)
l=toupper(sub(p,"\\1",k))
c=as.double(sub(p,"\\2",k))
D(l,c)}
R(f,u)}
a=R(A,u)
L=names(tail(sort(table(a$l)),20))
x=subset(a,l%in%L)
arrange(ddply(x, "l",summarise,n=length(c),a=mean(c),m=quantile(c,0.5)),-n)

डी-golfed:

library(XML)
library(plyr)
LoopBind <- function(FUN, ...) do.call(rbind, Map(FUN, ...))
GetQuestions <- function(url) {
  d = htmlParse(url)
  a=as.double(sub(".*?(\\d+)a.*","\\1",xpathSApply(d, "//div[starts-with(@class, 'status')]", xmlValue)))
  u=paste0("http://codegolf.stackexchange.com/",xpathSApply(d, "//*[contains(@class, 'question-hyperlink')]", xmlGetAttr, "href"))
  data.frame(u, a)
}
u <- sprintf("http://codegolf.stackexchange.com/questions/tagged/code-golf?page=%i", 1:50)
q <- do.call(rbind, Map(GetQuestions, u))
u <- with(q, head(u[a > 20], 50))

GetAnswers <- function(url) {
  u=sprintf("%s?page=%i",url,1:10)
  f=function(u) {
    d = htmlParse(u)
    h = xpathSApply(d, "//div[@class='post-text']//h1", xmlValue)
    p = "^(.*?),.*? (\\d+)( [Bb]ytes)?$"
    k = grep(p,h,v=T)
    l = toupper(sub(p,"\\1",k))
    c = as.double(sub(p,"\\2",k))
    data.frame(language=l,c)
  }
LoopBind(f,u)
}
a=LoopBind(GetAnswers, u)
L=names(tail(sort(table(a$l)),20))
x=subset(a,language%in%L)
arrange(ddply(x, "language", summarise, num_answers = length(c), avg_count = mean(c), median_count = quantile(c,0.5)),
        -num_answers)

6
6000 बाइट्स के लिए C # की औसत लंबाई कितनी है?
SuperJedi224

@ SuperJedi224 - कुछ बेहद लंबी प्रस्तुतियाँ हो सकती हैं जो औसत को कम कर रही हैं। यही कारण है कि माध्य एक उपयोगी आँकड़ा है क्योंकि यह आउटलेर्स के लिए प्रतिरोधी है।

1
मैंने कहीं पढ़ा कि C # सबसे कम गोल्फ वाली भाषा है। अब मुझे पता है क्यों ...
ev3commander

@ ev3commander - सी # की तुलना में pales एकल ...
Comintern

@Comintern: ईक ...
ev3commander

6

पायथन 2, 934 - 44 (यूआरएल सामान) = 890 बाइट्स

एपीआई का उपयोग करना:

from urllib2 import urlopen as u
from gzip import GzipFile as f
from StringIO import StringIO as s;x="https://api.stackexchange.com/2.2%s&site=codegolf"
import re;j=u(x%'/search/advanced?pagesize=50&order=desc&sort=creation&answers=20&tagged=code-golf');q=s(j.read());g=f(fileobj=q);true=1;false=0;l=';'.join(str(a['question_id'])for a in eval(g.read())['items']);w=[]
def r(p):
 j=u(x%('/questions/%s/answers?page=%s&filter=!9YdnSMlgz&pagesize=100'%(l,p)));g.seek(0);q.truncate();q.write(j.read());q.seek(0);k=eval(g.read());w.extend(a['body_markdown']for a in k['items'])
 if k['has_more']:r(p+1)
r(1);x={};s=sorted
for m in w:
 try:
  l,n=re.match("(.*?),.*?([0-9]+)[^0-9]*$",m.splitlines()[0]).groups();l=re.subn("# ?","",l,1)[0].upper()
  if l not in x:x[l]=[]
  x[l]+=[(l,int(n))]
 except:pass
for l in s(x,cmp,lambda a:len(x[a]),1)[:20]:
 v=s(x[l])
 print l,len(v),sum(map(lambda a:a[1],v))/len(v),v[len(v)/2][1]

ध्यान दें कि यह कोड API थ्रॉटलिंग पर ध्यान नहीं देता है

आउटपुट:

RUBY 60 430 32
PYTH 57 426 16
CJAM 56 35 23
C 52 170 76
PYTHON 2 51 88 79
JULIA 42 63 48
HASKELL 42 81 63
JAVASCRIPT (ES6) 41 96 83
PERL 40 44 27
PYTHON 3 37 91 89
PHP 36 98 59
JAVASCRIPT 36 743 65
POWERSHELL 35 86 44
JAVA 32 188 171
R 30 73 48
MATLAB 25 73 51
MATHEMATICA 24 57 47
APL 22 14 13
SCALA 21 204 59
TI-BASIC 21 42 24

1
@StewieGriffin दिलचस्प रूप से, मुझे /questionsकमी के लिए अर्हता प्राप्त करने के लिए एक अतिरिक्त स्लैश को दूसरी पुनरावर्ती क्वेरी में जोड़ना था ।
पोपरी

2
मतभेद इसलिए हैं क्योंकि @flodel के अलावा अन्य प्रत्ययों कोbytes नापसंद करता है , जबकि मेरा अन्य प्रत्ययों को संभाल लेगा chars
पोपरी

क्या यह संभव है कि आपका कोड C, C # और संभवतः C ++ को मिला दे? ऐसा लगता नहीं है कि 73 सी-उत्तर हैं।
स्ट्यू ग्रिफिन

नहीं, मुझे ऐसा नहीं लगता। मैं पहले अल्पविराम पर भाषा का नाम समाप्त करता हूं।
२०:५ery पर पोपरी

1
लगता l=re.sub("# ?|,","",l)है कि C # के साथ C # की जगह क्या है
flodel
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.