ETAOIN SHRDLU गोल्फ


43

चुनौती का संक्षिप्त और मीठा विवरण: ETAOIN SHRDLU के
आधार पर , आपकी चुनौती किसी भी भाषा में सबसे छोटा प्रोग्राम या फ़ंक्शन लिखना है जो इनपुट में उनकी आवृत्ति के आधार पर अंग्रेजी वर्णमाला के 26 अक्षरों को आउटपुट करता है।

वास्तव में लंबा, सूखा और पूरी तरह से विनिर्देश:

  • आपके कार्यक्रम / फ़ंक्शन को इनपुट के रूप में एक स्ट्रिंग मिलेगी पाठ, जिसमें एक या एक से अधिक अपरकेस और / या लोअरकेस अक्षर होंगे और इसमें विराम चिह्न, अंक, प्रतीक और अन्य गैर-अक्षर वर्ण भी हो सकते हैं।
  • प्रोग्राम / फ़ंक्शन को अंग्रेजी वर्णमाला के केवल 26 UPPERCASE पत्र का उत्पादन करना चाहिए , जिसमें इनपुट में प्रकट नहीं होने वाले, इनपुट में दिखाई देने वाले कितने समय के आधार पर सबसे कम से कम लगातार आदेश दिए गए हैं।
  • संपादित करें: आवृत्ति की गणना मामले-असंवेदनशील तरीके से की जाती है, लेकिन आउटपुट अपरकेस में होना चाहिए।
  • यदि दो या अधिक अक्षरों में समान आवृत्ति होती है, तो वे किसी भी क्रम में हो सकते हैं।
  • व्हॉट्सएप जैसे किसी अन्य आउटपुट की अनुमति नहीं है।
  • संपादित करें 7/1/2014: प्रतिक्रिया के आधार पर, मैं इस नियम में संशोधन कर रहा हूं। अनुमति दी गई केवल अन्य आउटपुट वैकल्पिक अग्रणी और / या अनुगामी व्हाट्सएप है, जैसे कि अनुगामी न्यूलाइन। किसी अन्य आउटपुट की अनुमति नहीं है।
  • अपरिभाषित व्यवहार को इनपुट के लिए अनुमति दी जाती है जिसमें कोई अक्षर नहीं होता है।

विजेता को अब से 7 दिन बाद चुना जाएगा, इसलिए उन उंगलियों को टाइप करें!


उदाहरण इनपुट:

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Praesent vitae erat velit. Mauris gravida euismod libero ut tincidunt. Phasellus elit dui, consectetur et egestas in, aliquam vitae diam. Donec eget varius ante. Vestibulum cursus diam aliquet, egestas orci quis, placerat dolor. Proin vel nisi lectus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Aliquam erat volutpat. Etiam libero tortor, ornare id dui eget, posuere dignissim libero. Pellentesque commodo consequat volutpat. Integer hendrerit sapien libero, vel viverra augue facilisis sit amet. Quisque consectetur eget nisl quis dignissim. Ut lacinia pretium quam a placerat.
Morbi sed interdum risus, nec pretium lectus. Morbi imperdiet est id accumsan molestie. Duis sed fermentum nisl. Nunc vitae augue mattis, dictum lectus vel, accumsan nisl. Sed ultricies adipiscing rhoncus. Vivamus eu lacus a enim venenatis eleifend. Praesent consectetur tortor non eleifend ultricies. Mauris et odio posuere, auctor erat at, fringilla est. Proin in vestibulum erat. Maecenas congue commodo ante vel varius. Sed tempus mi ut metus gravida, nec dictum libero dapibus. Morbi quis viverra elit. Ut pharetra neque eget lacus tincidunt dictum. Fusce scelerisque viverra tellus et pretium.
Fusce varius adipiscing odio. Nulla imperdiet faucibus sem, at rhoncus ipsum adipiscing vitae. Phasellus imperdiet congue lacus et mollis. Nullam egestas mauris magna, et mollis lectus varius ut. Sed sollicitudin adipiscing dolor, vel elementum elit laoreet molestie. Aliquam nec nulla vel sem ultrices ullamcorper. Nullam nec felis magna. Duis sodales orci non justo aliquam tempus. Integer mi diam, tempor sed vulputate et, varius et nunc. Vestibulum sodales ipsum id mi pharetra, ut convallis mi accumsan. Sed dictum volutpat vestibulum.
Quisque ac dolor sagittis, aliquam libero at, euismod enim. Nulla ullamcorper posuere nulla vitae varius. Nam at dolor non libero elementum pellentesque in in lorem. Fusce porttitor turpis in quam placerat varius. Donec lorem orci, condimentum eu sapien sit amet, aliquet commodo magna. Quisque sed lectus sit amet arcu euismod accumsan et non nunc. Phasellus placerat congue metus, feugiat posuere leo dictum quis. Sed ultricies feugiat eros dignissim bibendum.
Mauris scelerisque consectetur libero eget varius. Aenean neque nunc, ullamcorper vitae orci in, auctor ornare sapien. Nam lacinia molestie imperdiet. Nam vitae mattis nibh. Vestibulum consequat tellus ac nisi sagittis pulvinar. Nullam mollis ornare quam, et venenatis leo porttitor sit amet. Nulla urna neque, dignissim non orci ut, volutpat ultrices erat. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Pellentesque vestibulum tellus nec eros faucibus porta.

उदाहरण आउटपुट:

EITUSALNROMCDPVGQBFHJKWXYZ

नोट: KWXYZउस इनपुट के बीच 5 रास्ता टाई है ।

संपादित करें:

प्रतियोगिता खत्म हो गई है! उन सभी को धन्यवाद जिन्होंने भाग लिया। और अब विजेता (ओं!) के लिए: डेनिस के सीजम और इसाॅक दोनों के पाइथ के उत्तर दोनों में 19 अक्षर थे। (क्षमा करें, लेकिन मैं दोनों में से किसी भी उत्तर को स्वीकार नहीं करने वाला हूं क्योंकि मुझे लगता है कि यह दूसरे के साथ अनुचित होगा।) संपादित करें: डेनिस की सलाह लेते हुए, मैं उनके उत्तर को स्वीकार करने के लिए जा रहा हूं क्योंकि वह पहले थे। 19 वर्णों तक पहुँचें। माननीय उल्लेखों में इल्मरी करोनन के तीसरे स्थान पर 22 अंकों के साथ गोल्फ ग्राउंडस्क्रिप्ट के जवाब के साथ-साथ अंडरग्राउंडोरेल के 75-चार पायथन के उत्तर पर जाते हैं जिन्हें सबसे अधिक उत्थान मिला। एक बार फिर, भाग लेने वाले सभी को धन्यवाद!


क्या आवृत्ति केवल इनपुट के ऊपरी मामले पत्रों के लिए मापा जाता है?
हावर्ड

2
@IlmariKaronen व्हॉट्सएप के रूप में हां की नई रूपरेखाएं गिनाती हैं ताकि अनुमति न दी जाए।
अब्राहम

8
@ अंबरम: आईएमओ; यदि कुछ भाषाओं के लिए एक अनुगामी न्यूलाइन (विशेष रूप से) की अनुमति है, तो इसे आम तौर पर सभी भाषाओं के लिए अनुमति दी जानी चाहिए; कम से कम नहीं क्योंकि एक पाठ धारा को ईओएफ द्वारा पीछा की गई एक नई पंक्ति द्वारा समाप्त किया जाना चाहिए।
विलीहम टटलैंड

3
आपकी टिप्पणी की संख्या के आधार पर @illihamTotland ने मुझे एक नई रूपरेखा की अनुमति देने के लिए नियमों को संशोधित किया है।
अब्राहम

1
यदि सबसे छोटे कोड के साथ दो उत्तर हों तो क्या करें? पहले के समाधान के लिए हरी चेकमार्क प्रदान करने का सुझाव देता है। isaacg ने अपना जवाब पहले पोस्ट किया, मैंने पहली बार 19 बाइट्स में मुझे गोल्फ दिया। आप जो भी टाई ब्रेकर लेंगे, वह मेरे हिसाब से ठीक रहेगा, लेकिन मेरे लिए बिल्कुल सही जवाब नहीं है।
डेनिस

जवाबों:


26

CJam, 21 19 बाइट्स

qeu:A;'[,65>{A\-,}$

इसे ऑनलाइन आज़माएं।

उदाहरण

$ cjam etaoin.cjam <<< "~XyxY YyxZ"
YXZABCDEFGHIJKLMNOPQRSTUVW

(कोई नई पंक्ति नहीं)

यह काम किस प्रकार करता है

qeu:A; " Read from STDIN, convert to uppercase, save in the variable “A” and discard, ";
'[,    " Push an array of all ASCII characters before “[” (NUL to “Z”).               ";
65>    " Remove the first 64 characters (NUL to “@”).                                 ";
{      " Sort the array of characters by the following mapping:                       ";
  A\   " Swap the character with the string saved in variable “A”.                    ";
  -    " Remove all occurrences of the character from the string.                     ";
  ,    " Push the length of the string.                                               ";
}$     "                                                                              ";

अधिक घटनाओं का मतलब है कि अधिक वर्ण हटा दिए जाते हैं, इसलिए सबसे अधिक वर्ण सरणी की शुरुआत में दिखाई देते हैं।


वास्तव में बहुत चालाक।
अब्राहम

बधाई @Dennis प्रतियोगिता जीतने पर!
अब्राहम

43

अजगर 2 या 3 - 77 75 बाइट्स

f=lambda s:''.join(sorted(map(chr,range(65,91)),key=s.upper().count))[::-1]

एसटीडीआईएन से इनपुट हासिल करने से पहले मेरे पास एक जवाब था, लेकिन मुझे लगा कि यह तकनीकी रूप से अमान्य है। मैंने उपयोग किया था input()जिसे केवल एक ही लाइन मिलती है, लेकिन प्रश्न का उदाहरण इनपुट का तात्पर्य है कि इसे एक ही बार में कई लाइनों को संभालना चाहिए। कल्पना को पूरा करने के लिए, मैंने अपने जवाब को एक फ़ंक्शन में बदल दिया जो एक स्ट्रिंग तर्क लेता है। मेरे आश्चर्य के लिए, यह दो बाइट्स छोटा था! यह मेरे साथ नहीं हुआ print(...)और इससे input()अधिक लंबा था f=lambda s:और s

यह भी पायथन 2 और पायथन 3 के साथ उत्तर को संगत बनाता है। मूल रूप से यह केवल पायथन 3 था, क्योंकि इसका इस्तेमाल किया input()गया था (जिसे raw_input()2 में कहा जाता था )। अब चूंकि यह एक फ़ंक्शन है, यह दोनों में काम करता है।

व्याख्या की

                                  range(65,91)                              # The numbers 65 to 90
                          map(chr,range(65,91))                             # Convert to ASCII

                                                    s                       # The input string
                                                    s.upper()               # Convert to uppercase
                                                    s.upper().count         # Function literal for 'how many times the argument appears in the string'

                   sorted(map(chr,range(65,91)),key=s.upper().count)        # Sort by that function
           ''.join(sorted(map(chr,range(65,91)),key=s.upper().count))       # Concatenate to string
           ''.join(sorted(map(chr,range(65,91)),key=s.upper().count))[::-1] # Step through by -1 (i.e. reverse string)

  lambda s:''.join(sorted(map(chr,range(65,91)),key=s.upper().count))[::-1] # Make it a function (`return` is implicit for lambdas)
f=lambda s:''.join(sorted(map(chr,range(65,91)),key=s.upper().count))[::-1] # Give it a name

2
दूसरी ओर, स्पष्टीकरण में टिप्पणियां मुझे मुखर बनाती हैं। सीएस 101 में आपका स्वागत है!
इजाकाता

6
@ इज़काटा महत्वपूर्ण बात यह है कि यह आपको दिखाता है कि कोड को किस क्रम में पढ़ना है। क्योंकि गोल्फ कोड पढ़ना शुरू करने के लिए सबसे अच्छी जगह शायद ही कभी स्पष्ट होती है, खासकर जब यह थोड़ा अधिक जटिल या इसके मुकाबले अधिक हो जाता है।
मार्टिन एंडर

1
सुंदर प्रस्तुति!
xnor

3
@ इज़क मेरा लक्ष्य ऐसे लोगों को समझने में सक्षम बनाना था जो अजगर को नहीं जानते हैं। मैं कभी भी वास्तविक परियोजना में इस तरह की टिप्पणी नहीं करूंगा।
भूमिगत

2
@ नंबर countनहीं एक चर या कुछ भी नहीं है, यह एक शाब्दिक कार्य है। यह जितना अच्छा होगा , सामने वाले -1को चिपकाकर किसी फ़ंक्शन के रिटर्न मान को गुणा करने में सक्षम होगा -, यह एक विशेषता पायथन नहीं है।
भूमिगत

15

बैश, 65 बाइट्स

(tr a-z A-Z;echo {A..Z})|fold -1|sort|uniq -c|sort -nr|tr -dc A-Z

उदाहरण

$ bash etaoin.sh <<< "~AbaB BbaC"
BACZYXWVUTSRQPONMLKJIHGFED

यह काम किस प्रकार करता है

(              #
  tr a-z A-Z   # Turn lowercase into uppercase letters.
  echo {A..Z}  # Print all uppercase letters.
) |            #
fold -1 |      # Split into lines of length 1.
sort |         # Sort those lines (required for piping to uniq).
uniq -c |      # Print the frequencies of all lines.
sort -nr |     # Sort by frequency (reversed).
tr -dc A-Z     # Remove everything that's not an uppercase letter.

1
यह लोकेल पोर्टेबल नहीं है, आपको LC_COLLATE = C (या कम, LC_ALL) को बाध्य करने की आवश्यकता है।
क्रिस डाउन

6
@ क्रिसडाउन पोर्टेबिलिटी आमतौर पर कोड गोल्फ उत्तरों में चिंता का विषय नहीं है।
केविन

1
पोर्टेबिलिटी के बिना, यह उत्तर क्या करता है, यह अच्छी तरह से परिभाषित नहीं है।
क्रिस डाउन

@ क्रिसडाउन: मैंने कुछ तार और कुछ स्थानों का परीक्षण किया है, लेकिन मुझे एक उदाहरण नहीं मिला जहां अक्षर वर्णों के लिए यूनीक गलत व्यवहार करता है। क्या आप मुझे दिखा सकते हैं?
डेनिस

@ChrisDown यह स्क्रिप्ट पोर्टेबल है, जो शेल, बैश या ksh93 है, तो BSD संस्करणों को फोल्ड, सॉर्ट, ट्र, यूनीक के बीएसडी संस्करण पर चलाने के लिए पर्याप्त है। अन्य गोले, जैसे zsh, का विस्तार करने में विफल {A..Z}। सभी LC_COLLATE स्थान काम करते हैं, क्योंकि OpenBSD में केवल LC_COLLATE = C होता है।
kernigh

12

पायथ 1.0.2 , 19 20

=ZUwsVm;dSm[cZkk)UG

इसे यहाँ आज़माएँ: http://ideone.com/fork/YlWpEJ

Pyth के बारे में और जानें यहाँ: http://esolangs.org/wiki/Pyth

उदाहरण:

ETAOIN SHRDLU के आधार पर, आपकी चुनौती किसी भी भाषा में सबसे छोटा प्रोग्राम या फ़ंक्शन लिखना है जो इनपुट में उनकी आवृत्ति के आधार पर अंग्रेजी वर्णमाला के 26 अक्षरों को आउटपुट करता है।

देता है:

TENOHARSIULGFPYDCBWQMZXVKJ

स्पष्टीकरण:

=ZUw: इनपुट को अपरकेस में बदलें और Z में स्टोर करें।

sV: के रिवर्स के योग को प्रिंट करें

m;d: की अंतिम प्रविष्टियाँ

S: बढ़ते क्रम में, उनकी पहली प्रविष्टि द्वारा क्रमबद्ध

m[cZkk): सूचियाँ [Z, k में k की गिनती]

UG: बड़े अक्षरों में कश्मीर के लिए।

समान पायथन समकक्ष:

G='abcdefghijklmnopqrstuvwxyz'
Z=copy(upper(input()))
print(_sum(rev(_map(lambda d:d.pop(),sorted(_map(lambda k:_list(count(Z,k),k),upper(G)))))))

यह प्रविष्टि नहीं है, मुझे लगा कि लोग इसे देखना पसंद करेंगे। पायथ 1.0.4 में, निम्न कार्यक्रम 10 वर्णों में एक समाधान है:

JUwo_cJNUG

स्पष्टीकरण:

JUw: जे में अपरकेस और स्टोर में इनपुट कन्वर्ट करें।

o: (प्रिंट) द्वारा क्रमबद्ध करें

_cJN: -1 * (J में N की गिनती)

UG: अपरकेस अक्षरों में ओवर एन।

यह एक कानूनी समाधान नहीं है क्योंकि oइस समस्या के जवाब में, Pyth 1.0.2 से 1.0.4 तक के कई बदलाव शामिल हैं, जैसे कि, इसके अनुसार, फ़ंक्शन।


मेरा सुझाव है कि यदि आप मौजूद हैं, तो आप Pyth के आधिकारिक पेज पर Pyth लिंक को अपडेट करें।
AL

@AL यह पाइथ का आधिकारिक पेज है, जब तक कि मैं एक एसोलंग प्रविष्टि नहीं डाल देता।
isaacg

आपको एक Zबार बाद में इसे संदर्भित करने के लिए इनपुट को चर में संग्रहीत करने की आवश्यकता क्यों है ? क्या Zइसके स्थान के लिए एक्सप्रेशन डालने से इनपुट को कई बार पढ़ा जा सकता है?
xnor

@xnor Z का उपयोग उस स्थिति में किया जाता है, जो लंबोदर फ़ंक्शन के अंदर है, क्योंकि यह मैप के पहले तर्क में है, इसलिए इसे एक वैरिएबल में सहेजने की आवश्यकता है। Uw का उपयोग करने से वास्तव में इनपुट 26 बार पढ़ा जाएगा।
ईसैक

1
@AL ठीक है, पाइथ इसोल और गितुब दोनों पर है। गितुब लिंक एस्लांग पृष्ठ के निचले भाग में है, जो उत्तर में जुड़ा हुआ है। Github कोड रंगीकरण करता है।
इसहाक

11

जावास्क्रिप्ट ( ईएस 6 ) 119 117

संपादित करें: (-2) कॉल toUpperCaseमें केस-असंवेदनशील RegEx का उपयोग करने की आवश्यकता को हटा दिया split

a=prompt(f=x=>a.split(RegExp(x,'i')).length)
alert([...'ABCDEFGHIJKLMNOPQRSTUVWXYZ'].sort((b,c)=>f(c)-f(b)).join(''))

वैकल्पिक (एक ही लंबाई): एक एकल फ़ंक्शन में सॉर्ट और वर्ण की गणना की गई।

a=prompt()
alert([...'ABCDEFGHIJKLMNOPQRSTUVWXYZ'].sort(f=(b,c)=>c?f(c)-f(b):a.split(RegExp(b,'i')).length).join(''))

एक समारोह के रूप में: 105 104

संपादित करें: (-1) किसी एकल फ़ंक्शन में सॉर्ट और कैरेक्टर काउंटिंग को कंडेन्स्ड करें।

F=a=>[...'ABCDEFGHIJKLMNOPQRSTUVWXYZ'].sort(f=(b,c)=>c?f(c)-f(b):a.split(RegExp(b,'i')).length).join('')

1
दिलचस्प तकनीक।
मैट

1
एक स्ट्रिंग छींटे ... रमणीय!
बर्गी जूल

10

GolfScript, 22 वर्ण

:?91,+-26>{.32+]?\-,}$

इसे ऑनलाइन आज़माएं।

स्पष्टीकरण:

  • :?प्रतीक को इनपुट स्ट्रिंग प्रदान करता है ?। (मैं एक विराम चिह्न का उपयोग करता हूं ताकि निम्नलिखित संख्या 91प्रतीक नाम के भाग के रूप में पार्स न हो।)
  • 91,0 से 90 (ASCII कोड Z) की संख्याओं की सूची बनाता है ।
  • + इस सूची को इनपुट स्ट्रिंग में जोड़ता है, जिससे यह ASCII कोड की एक सरणी से स्ट्रिंग में परिवर्तित हो जाता है (और आसानी से स्टैक से इनपुट स्ट्रिंग को हटाता है)।
  • -26>इस स्ट्रिंग के अंतिम 26 अक्षरों को लेता है, जिसमें से एक बड़े अक्षर ASCII अक्षरों वाले स्ट्रिंग का निर्माण होता Aहै Z
  • { }$इनपुट स्ट्रिंग में वर्णों सभी कोड ब्लॉक लागू होता है, और परिणाम के अनुसार उन अक्षरों को क्रमबद्ध करता है।
  • कोड ब्लॉक के अंदर, .चरित्र को डुप्लिकेट 32+करता है और कॉपी को अपरकेस से लोअरकेस में कनवर्ट करता है। ]एक सरणी में इन दो पात्रों एकत्र करता है, ?\-में संग्रहीत इनपुट स्ट्रिंग लेता है ?और इसे से सरणी में पात्रों की सभी घटनाओं निकाल देता है, और ,गिनती शेष स्ट्रिंग की लंबाई, जो तरह कुंजी हो जाएगा। इस कुंजी द्वारा वर्णों को आरोही क्रम में क्रमबद्ध किया जाएगा, और इस प्रकार घटित क्रम से घटते क्रम में हो जाएगा।

1
लगता है कि हमारे पास एक ही विचार था। माइनर बग: Z अक्षर गायब है। यह होना चाहिए 91,+-26>
डेनिस

@ डेनिस: आह, उफ़। फिक्स्ड, हालांकि जो भी उस पत्र की जरूरत है? :)
इल्मरी करोनन

2
@IlmariKaronen सामुदायिक फीडबैक के आधार पर, मैंने एक अनुगामी न्यूलाइन की अनुमति देने के लिए नियमों में संशोधन किया (संपूर्ण विवरण के लिए प्रश्न देखें)। आपका स्कोर अब :) के 22बजाय 25:)
अब्राहम

8

हास्केल, 110 बाइट्स

import Data.List
import Data.Char
a%f=compare(f a).f
f t=sortBy(% \c->length$filter((/=c).toUpper)t)['A'..'Z']

उदाहरण का उपयोग:

λ> f "Based off ETAOIN SHRDLU, your challenge is to write the shortest program or function in any language that outputs the 26 letters of the English alphabet based on their frequency in the input."
"ETNAHORISULFGPBCDYMQWJKVXZ"

1
के बारे में क्या (/=c)और छुटकारा 0-?
लिन

@ मौरिस की अच्छी पकड़! मैंने इसे संपादित किया और एक अन्य चरित्र का मुंडन किया।
फ़्लैंक

6

रूबी 2.0, 53 अक्षर

संपादित करें : मल्टीलाइन स्ट्रिंग्स के साथ सही ढंग से काम करने के लिए तय किया गया, धन्यवाद @ durron597!

f=->s{$><<(?A..?Z).sort_by{|c|-s.upcase.count(c)}*''}

एक फ़ंक्शन बनाता है जिसे fनिम्नानुसार उपयोग किया जा सकता है:

f['jackdaws love my big sphinx of quartzzz']

प्रिंट करने के लिए प्रिंट:

AZOSICGHEJKLMBFPQRDTUVWXYN

2
यह उत्तर सही नहीं है। यह इसका उत्तर देता है: EITASUROLNCMPDVQGBHFKJWXYZउदाहरण के लिए प्रश्न में
डुर्रोन 597

1
@ durron597 धन्यवाद, आप सही हैं! यह मल्टीलाइन स्ट्रिंग्स को सही तरीके से हैंडल नहीं कर रहा था - getsएक समय में एक लाइन देता है। इसे बदलकर तय किया जा सकता getsहै, gets$nलेकिन इसे फ़ंक्शन में बदलना 1 चार्ट छोटा है।
पॉल प्रेस्टिज जूल

6

पर्ल, 54 46 बाइट्स

अद्यतन: आगे के अनुकूलन के बाद इसे 46 बाइट तक निचोड़ा जा सकता है : ( / हैक के लिए thx डेनिस ; चीनी हैक के लिए पर्ल -> हैक)-n{}<=>-

s/./$h{uc$&}++/eg}{say sort{$h{$b}-$h{$a}}A..Z

इसे रन के साथ चलाया जाना है perl -nE

मूल समाधान (विशेष पर्ल विकल्पों की आवश्यकता नहीं है):

s/./$h{uc$&}++/egfor<>;print sort{$h{$b}<=>$h{$a}}A..Z

पर्ल 5.8.3, 5.14.2 में सत्यापित

यदि आपको कोई चेतावनी मिलती है, तो अलग egऔर forएक स्थान (+1 चार) के साथ, यदि आपको कोई आपत्ति हो

उदाहरण का उपयोग:

$ python -c 'import this' | perl -le 's/./$h{uc$&}++/egfor<>;print sort{$h{$b}<=>$h{$a}}A..Z' 2>/dev/null
ETAISONLRHPBUCDYMFGXVWKZJQ

विस्तार: .प्रत्येक इनपुट लाइन ( for<>) के प्रत्येक वर्ण ( ) पर , एक प्रतिस्थापन "पैटर्न" लागू करें, जिसका वास्तव में एक अभिव्यक्ति ( eध्वज s///) के रूप में मूल्यांकन किया जाता है , जो एक बढ़ा हुआ ( uc) वर्ण बढ़ाता है ( ./ $&अधिक स्पष्ट (.)/ छोटा है ) $1) (अनइंस्टाल्यूटेड) हैश ( %h) में गिनती । फिर, अक्षर आवृत्ति हैश का उपयोग सही क्रम में ऊपरी-केस वर्णमाला को प्रिंट करने के लिए एक तरह के तुलना समारोह में किया जाता है।


1
छोटा और कोई त्रुटि संदेश नहीं:perl -ne 's/./$h{uc$&}++/eg}{print sort{$h{$b}<=>$h{$a}}A..Z'
डेनिस

डेनिस: बहुत दिलचस्प, यह एक टाइपो की तरह लग रहा है .. wth यह है? मैं कुछ वेरिएंट का उपयोग कर रहा था -nऔर END{}, लेकिन वे हमेशा लंबे समय तक थे .. यदि आप चाहते हैं तो जवाब अपडेट करने के लिए स्वतंत्र महसूस करें
mykhal

1
हां, कोड के चारों ओर -nलपेटता है while(<>){...}। मैं अन्य उपयोगकर्ताओं के कोड को संपादित करने से बचता हूं। गलती करना बहुत आसान है, कुछ चीजें केवल कुछ कंप्यूटरों पर काम करती हैं, आदि
डेनिस

1
जो: मैं }{"इंजेक्शन" के बारे में बात कर रहा था , न कि केवल प्रसिद्ध -nविकल्प के बारे में । एक उम्मीद नहीं कर सकता है कि कोड स्ट्रिंग वास्तव में तकनीकी रूप से निष्पादन से पहले लूप कोड स्ट्रिंग द्वारा लपेटी गई है, न केवल निष्पादन से पहले, बल्कि यह किसी तरह काम करता है जैसे कि यह लपेटा गया था ..
mykhal

1
दो और चार्ट बचाओ: $h{$b}<=>$h{$a}साथ में बदलें$h{$b}-$h{$a}
चीनी पर्ल गोथ

5

आर, 123 बाइट्स

कोड @RichieCotton द्वारा सुझावों के लिए धन्यवाद में सुधार हुआ है।

text <- "Based off ETAOIN SHRDLU, your challenge is to write the shortest program or function in any language that outputs the 26 letters of the English alphabet based on their frequency in the input."

f=function(x){b=plyr::count(toupper(strsplit(x,"")[[1]]));c=merge(LETTERS,b,all.x=T);paste(c[order(-c$freq),1],collapse="")}

f(text)

आउटपुट:

> f(text)
[1] "ETNAHORISULFGPBCDYMQWJKVXZ"

1
@ रीचीकॉटन: मैंने आपके सुझाए गए संपादन को अब दो बार अस्वीकार कर दिया है। मुझे नहीं पता कि यदि आपको अस्वीकार मत के कारण से सूचित किया जाता है, तो यदि आप इसे पढ़ते हैं: कृपया टिप्पणियों में गोल्फ सुधार प्रदान करें, इसलिए ओपी उनकी समीक्षा कर सकता है। यहाँ क्यों है: meta.codegolf.stackexchange.com/a/1619/8478
मार्टिन

4

सी ++, 185 183 179 177 बाइट्स

जीतने की उम्मीद नहीं, बेशक (C ++ कभी जीत सकता है?) लेकिन फिर भी एक मजेदार व्यायाम।

#include <algorithm>
#include <stdio.h>
int f[256],p;main(){for(p=65;p<91;p++)f[p]=p;while(~(p=getchar()))f[p&95]+=256;p=256;std::sort(f,f+p);while(p--)f[p]&95&&putchar(f[p]);}

स्पष्टीकरण:

#include <algorithm>         // for std::sort
#include <stdio.h>           // for getchar, putchar
int f[256],p;                // declare an array of count-prefixed chars, and a counter
main(){
    for(p=65;p<91;p++)       // 65 == 'A', 91 == the character after 'Z'
        f[p]=p;              // set the character for the slot
    while(~(p=getchar()))    // read characters until EOF
        f[p&95]+=256;        // increment the packed count for the character stripped of the 'lowercase bit'
    p=256;                   // start a countdown
    std::sort(f,f+p);        // sort the array
    while(p--)               // do the countdown
        f[p]&95 &&           // if the masked-off character is set...
          putchar(f[p]);     // print it
}

4

VBScript 181 109

एक पूरी तरह से अलग एल्गोरिथ्म का उपयोग करने के लिए अद्यतन किया गया। बीट्स जावास्क्रिप्ट!

सुंदर:

dim b(99):i=ucase(inputbox(k))
for y=65to 90
    c=chr(y)
    a=len(replace(i,c,k))
    b(a)=c+b(a)
next
msgbox join(b,k)

golfed:

dim b(99):i=ucase(inputbox(k)):for y=65to 90:c=chr(y):a=len(replace(i,c,k)):b(a)=c+b(a):next:msgbox join(b,k)

4

जे ४१ ३५ बाइट्स

(u:65+i.26)([\:[#/.~@,e.~#])toupper

डेमो:

i=: 'This is a test to see whether this is still working'
(u:65+i.26)([\:[#/.~@,e.~#])toupper i
STIEHLORWAGKNBCDFJMPQUVXYZ

स्पष्टीकरण:

(u:65+i.26) & ( [ \: [ #/.~@,e.~#]) toupper) )
ABCDE...          |    |    |   |      uppercase the right argument
                  |    |    |   \copy from right only member from left
                  |    |     \append the left argument
                  |    \ Afterwards Count apperances of each letter
                  \ Sort the left according to the appearances

कुंजी बाईं सरणी को जोड़ना है, जैसे कि सभी पत्र उपलब्ध हैं, और पहले से ही क्रम में हैं। कांटे के रूप में तीसरी संज्ञा के रूप में एक संज्ञा का उपयोग करने का एक अजीब परिणाम यह है कि यह क्रिया के साथ-साथ वाक्यांश के रूप में भी काम करता है।


4

ग्रूवी - 130 123 115 112 98 92

@ Cfrick की सलाह के अनुसार (दो बार!):

f={('A'..'Z').collectEntries{c->[c,it.grep(~/(?i)$c/).size()]}.sort{-it.value}*.key.join()}

एक छोटा परीक्षण (बेशर्मी से @jpjacobs से चुराया गया):

assert f('This is a test to see whether this is still working') == 
    'STIEHLORWAGKNBCDFJMPQUVXYZ'

और प्रस्तावित परीक्षा भी पास हो रही है


1
फ़ंक्शन को सभी 26 अक्षरों को आउटपुट करने की आवश्यकता है, न कि केवल इनपुट स्ट्रिंग में मौजूद हैं।
एल्गोरिथमशार्क

@ अल्गोरिद्मशर्क, वास्तव में, मेरी गलती, निश्चित
Lp

f={('A'..'Z').collectEntries{c->[c,it.toUpperCase().findAll(c).size()]}.sort{-it.value}.keySet().join()}104 के लिए
cfrick

1
एक और 6 बाइट्स: के it.grep(~/(?i)$c/)बजायit.toUpperCase().grep(c)
cfrick

@cfrick वाह! एक बार फिर धन्यवाद! वह toUpperCaseमुझे नरक से परेशान कर रहा था।
एलपी

4

SAS - 217 (मुझे लगता है)

इनपुट को कार्ड 4 कथन के बाद, या आपके सिस्टम के लिए उपयुक्त पंच कार्ड पर लाइन में रखा जाना चाहिए। मुझे लगता है कि यह दृष्टिकोण कुछ पात्रों बनाम इनपुट को उद्धृत करने का प्रयास करता है।

data a;
input;
S = upcase(compress(_INFILE_,,'ak'));
do i=1 to length(S);
l=substr(S,i,1);
output;
end;
cards4;
;;;;
run;
proc sql;
select l into :o separated by '' from
(select l, 1/count(l) as f from a group by l) order by f;
quit;

मुझे पता है कि यह पूरी कल्पना को पूरा नहीं करता है, क्योंकि यह केवल उन पात्रों को देता है जो इनपुट स्ट्रिंग में दिखाई देते हैं। मुझे इस पर थोड़ा पुनर्विचार करने की आवश्यकता हो सकती है।


युक्ति से नहीं मिलता है, लेकिन अभी भी शांत है, इसलिए +1: D
बिल्ली

4

AppleScript, 278

मैंने गौर किया "a" = "A" AppleScript में सच है। मैं कोड गोल्फ में इसका उपयोग कर सकता हूं, लेकिन बाकी स्क्रिप्ट बहुत खराब है। मैंने AppleScript 1.8.3 का इस्तेमाल किया।

यह एक फ़ंक्शन को परिभाषित करता है f। यदि आप f("a string")स्क्रिप्ट के निचले भाग में जोड़ते हैं और इसे स्क्रिप्ट संपादक में चलाते हैं, तो यह परिणाम दिखाएगा।

on c(n)
ASCII character(64+n)
end
on f(s)
set{a,r}to{{},""}
repeat with i from 1 to 26
set j to 0
repeat with b in s
if b&""=c(i)then set j to j+1
end
set a to a&j
end
repeat with j from 0 to(count s)
repeat with i from 1 to 26
if a's item i=j then set r to c(i)&r
end
end
r
end

प्रारूपित और टिप्पणी की गई:

-- Returns nth letter of alphabet.
on c(n)
    ASCII character (64 + n)
end c

-- Returns letters in s sorted by frequency.
on f(s)
    -- a: list of letter counts
    -- r: resulting string
    set {a, r} to {{}, ""}

    -- For each letter from A to Z,
    -- count letters in string s.
    repeat with i from 1 to 26
        set j to 0
        repeat with b in s
            -- Can't use b = c(i), because
            -- b is a reference to a string
            -- and = never dereferences its
            -- operands. Get contents of b,
            -- here by coercing b to string.
            if b & "" = c(i) then set j to j + 1
        end repeat
        -- Set item i of a to count j.
        set a to a & j
    end repeat

    -- Sort letters by frequency.  Do a counting sort
    -- because AppleScript lacks a sort command.
    repeat with j from 0 to (count s)
        repeat with i from 1 to 26
            if a's item i = j then set r to c(i) & r
        end repeat
    end repeat
    r
end f

-- Example call:
f("Now is the time for all good men to come to the aid of their country.")
-- Result: "OTEIRNMHLFDCAYWUSGZXVQPKJB"

3

वीबीएसस्क्रिप्ट 157 156 बाइट्स

संपादित करें: msgbox (p) को msgbox p में बदल दिया

अधिक पठनीय:

s=ucase(InputBox(z))    'z is empty.
L=len(s)
Dim a(255)
for i=1to L
    x=asc(mid(s,i))
    a(x)=a(x)+1
next
for t=0to L
    For i=65To 90
        If a(i)=t then p=chr(i)&p
    next
next
msgbox p

गोल्फ: (155 अक्षर + 1 गाड़ी वापसी)

s=ucase(InputBox(z)):L=len(s):Dim a(255):for i=1to L:x=asc(mid(s,i)):a(x)=a(x)+1:next:for t=0to L:For i=65To 90:If a(i)=t then p=chr(i)&p
next:next:msgbox p

मेरे पास यह 171 पहले कोड के साथ था जो मुझे अधिक दिलचस्प लगा, लेकिन आराम से ढंग की छँटाई विधि कम है और इसके लिए लेन (एस) की आवश्यकता होती है, जो पहले लूप के लिए "जबकि" से "कम" के लिए एक "बनाता है"। (जम्हाई)

's=UCase(InputBox(Z))&8 'just need any extra character.  0-7 don't work because &7 is octal

s=UCase(InputBox(Z)) 'nevermind
Dim a(999)
While Len(s)
    x=Asc(s) 'returns ascii of first char
    a(x)=a(x)-1 'going negative saves a character later...
    s=Mid(s,2) 'doesn't care if you run out of string
Wend
for j=1 to 26 'this used to be   While Len(p)<26
    For i=65To 90
        If a(i)<a(y) Then y=i 'it is barely not worth it to do a(i)+a(i+32)>a(y) here to skip the ucase() above
    Next
    p=p&Chr(y)
    a(y)=1 'if I didn't go negative this would have to be -1.  arrays default to 0.
Next
MsgBox(p)

मैंने इस पोस्ट से कुछ बेहतरीन ट्रिक्स सीखे! उल्लेख के लिए भी धन्यवाद। एक बात: मुझे लगता है कि for t=0होना चाहिए for t=1, अन्यथा आप हमेशा पूरी वर्णमाला छापते हैं।
आराम से

1
@comfortablydrei पूरे वर्णमाला को प्रिंट करना आवश्यक है। "प्रोग्राम / फंक्शन को अंग्रेजी वर्णमाला के केवल 26 UPPERCASE पत्र का उत्पादन करना चाहिए, जिनमें इनपुट में नहीं दिखाई देते हैं"
JesterBLUE

रुको। उस एक को याद किया। तो यह मेरी गलती है। धन्यवाद!
आराम से

3

जे - 38 35 चार

एक स्ट्रिंग के रूप में दाईं ओर इनपुट लेने वाला फ़ंक्शन। विजेता नहीं, लेकिन लिखने में मजा आया।

(u:65+i.26)([\:[#/.~@,e.~#])toupper

व्याख्या की:

  • toupperमानक पुस्तकालय में एक क्रिया है जो एक स्ट्रिंग को बढ़ाती है। यह तब क्रिया का सही तर्क बन जाता है, जबकि बायां तर्क वर्णमाला है: ASCII कोडपॉइंट 65 से 90।

  • [और दायीं आर्ग में उन अक्षरों ,e.~#])( #) का चयन करता है ( जो ]कि e.~बायें के तत्व हैं ( ), और फिर ,बायीं आर्ग ( [) को दिखाते हैं । बुद्धि के लिए, हम केवल बड़े अक्षरों को रखते हैं, और अंत में वर्णमाला की एक प्रति जोड़ते हैं, यह सुनिश्चित करने के लिए कि हम उन सभी को पकड़ते हैं।

  • #/.~@तब प्रत्येक वर्ण की आवृत्तियों देता है। ऐसा होता है कि यह वर्णानुक्रम में दिया गया है, इसलिए बाद में हम \:वर्णमाला (बाएं तर्क [) को डाउनसॉर्ट ( ) कर सकते हैं ।

नीचे एक त्वरित आलसी उदाहरण। आज़माएं बेझिझक इसे अपने लिए tryj.tk पर आज़माएं

   (u:65+i.26)([\:[#/.~@,e.~#])toupper 'Based off ETAOIN SHRDLU, your challenge is to write the shortest program or function in any language that outputs the 26 letters of the English alphabet based on their frequency in the input.'
ETNAHORISULFGPBCDYMQWJKVXZ

3

टी-एसक्यूएल 178

असल में, यह मेरा VBScript समाधान है लेकिन SQL में लागू किया गया है।

यह एक स्तंभ को संक्षिप्त करने के लिए एक्सएमएल आउटपुट दुरुपयोग है। व्यावहारिक उपयोग में, यह GROUP_CONCATMySQL और अन्य में कार्यों का अनुकरण करने के लिए एक बाहरी तालिका में शामिल हो सकता है।

@चर घोषित करना :

DECLARE @ CHAR(1024)= 'enter your text here';

कोड:

with y AS(
    SELECT UPPER(@)i,0l,91y
    UNION ALL
    SELECT i,len(replace(i,char(y-1),'')),y-1
    FROM y
    WHERE y>65
)
SELECT LTRIM(
(
    SELECT char(y)
    FROM y
    WHERE y<91
    ORDER BY l
    FOR XML PATH(''))
)

3

पर्ल, 78 बाइट्स

undef$/;$i=<>;$r{$i=~s/$_//gi}.=$_ for A..Z;print$r{$_}for sort{$b<=>$a}keys%r
  • बिना किसी सफेद स्थान के केवल 26 अपरकेस ASCII अक्षर आवृत्ति क्रम में आउटपुट होते हैं।
  • बंधे हुए अक्षर वर्णमाला क्रम में दिए गए हैं।

प्रश्न में उदाहरण के लिए परिणाम:

EITUSALNROMCDPVGQBFHJKWXYZ

Ungolfed:

# read input
# ----------
undef $/; # disable input separator
$i = <>;  # $i holds the complete input as one string

# analyze
# -------
# For each uppercase letter (A upto Z) its occurences are counted
# via the number of substitutions made by s/$_//gi. The lowercase
# letter is included via modifier "i".
# 
# The occurrence count is then used as key for hash %r.
# The uppercase letter is appended to the value of that hash entry.
$r{$i =~ s/$_//gi} .= $_ for A..Z;

# output
# ------
# The hash keys are sorted numerically in reverse order by
# the specified sort function.
print $r{$_} for sort {$b<=>$a} keys %r

यह उदाहरण के लिए काम कर सकता है, जैसे कि echo -e 'x\ny\n\nz\n'आउटपुट के लिए बीओटी नहीं , जिसे वापस लौटना चाहिए XYZABCDEFGHIJKLMNOPQRSTUVW, लेकिन XYABCDEFGHIJKLMNOPQRSTUVWZइसके बजाय उपज । क्यों लगता है .. :)
mykhal

@ यमखल: निश्चित।
Heiko Oberdiek

3

PHP - 105 बाइट्स

<?preg_filter(~‹§æ“Ö¢‹ö,'$f[$0&fl]++',join('',range(a,z)).$argv[1]);arsort($f);foreach($f as$l=>$F)echo$l;

यहाँ हेक्सडम्प, विशेष पात्रों का कारण है:

0000000 3c 3f 70 72 65 67 5f 66 69 6c 74 65 72 28 7e dc
0000010 a4 be d2 85 a2 dc 9a 2c 27 24 66 5b 24 30 26 df
0000020 5d 2b 2b 27 2c 6a 6f 69 6e 28 27 27 2c 72 61 6e
0000030 67 65 28 61 2c 7a 29 29 2e 24 61 72 67 76 5b 31
0000040 5d 29 3b 61 72 73 6f 72 74 28 24 66 29 3b 66 6f
0000050 72 65 61 63 68 28 24 66 20 61 73 24 6c 3d 3e 24
0000060 46 29 65 63 68 6f 24 6c 3b                     
0000069

और थोड़ा कम गोल्फ वाला संस्करण:

<?
preg_filter(           // regular expression
  "#[A-z]#e",          // matches every letter + 'eval' flag
  '$f[$0&fl]++',        // so this code runs for every letter
                       // $f is an array whose indices are uppercase letters
                       //   and whose values represent the number of occurences
                       // lowercase is converted to uc with the bitwise and
                       //   fl is 11011111 in binary, every bit except for 32's is set
  join('', range(a,z)) // adding abcdefghijklmnopqrstuvwxyz to the input
    .$argv[1]);        //   because not all letters have to appear in the input
arsort($f);            // sort $f in reverse, maintaining indices
foreach($f as$l=>$F)   //
  echo$l;              // print each index in order

उदाहरण:

 $ php etaoin_shrdlu.php "This function sorts an array such that array indices maintain their correlation with the array elements they are associated with."
 ATIRESHNOCYUWMDLFXZBVGPQKJ

खास किरदार कैसे preg_filter()काम करते हैं?
अब्राहम

3
PHP ~ में बिटवाइज़ NOT ऑपरेटर है, और आप इसे स्ट्रिंग्स पर भी लागू कर सकते हैं, जिस स्थिति में यह प्रत्येक वर्ण पर काम करता है। इसके अलावा, PHP टेक्स्ट के स्ट्रिंग को पार्स करने के लिए खुश है, क्योंकि स्ट्रिंग में दिए गए शब्द हैं कि उनमें कोई विशेष वर्ण नहीं हैं (जैसे ऑपरेटर, चर, अर्धविराम, पैरेन्थेस ...) के लिए $। तो, "# [Az] #e" के बजाय ~ Ö "Ö the ö (बिटवाइड इनवर्टेड वर्जन) लिखना एक बाइट को बचाता है, क्योंकि इसे उद्धृत नहीं किया जाना है।
ऑरेल बिएल

आह, धन्यवाद। अब समझ में आता है।
अब्राहम

1
PHP में कुछ भी समझ में नहीं आता है। पवित्र मोली।
शराबी

echo join(array_keys($f));एक बाइट बचा सकता है
टाइटस

3

लिनक्यूपैड में सी # - 203 बाइट्स

मैंने लोगान बांध के उत्तर के लिए एक अलग तरीका अपनाया। मैंने पहले यह सुनिश्चित किया कि इनपुट स्ट्रिंग के प्रत्येक वर्ण को उसके स्वरूप के अनुसार क्रमबद्ध किया गया है और केवल आउटपुट स्ट्रिंग में एक बार मौजूद है। उसके बाद मैंने वर्णमाला से आउटपुट स्ट्रिंग में प्रत्येक लुप्त चरित्र को जोड़ा।

void e(string i){var a="";foreach(var d in i.ToUpper().GroupBy(x=>x).OrderByDescending(u=>u.Count()))if(d.Key<91&&d.Key>64){a+=d.Key;}for(int x=65;x<91;x++)if(!a.Contains((char)x)){a+=(char)x;}a.Dump();}

अफसोस की बात यह है कि अगर मैं विजुअल स्टूडियो में बना होता तो लोगान डैम के जवाब को नहीं हराता।

अधिक पठनीय संस्करण:

void e(string i)
    {
        var a = "";
        foreach (var d in i.ToUpper().GroupBy(x => x).OrderByDescending(u => u.Count()))
        {
            if (d.Key < 91 && d.Key > 64)
            {
                a += d.Key;
            }
        }
        for (int x = 65; x < 91; x++)
        {
            if (!a.Contains((char)x))
            {
                a += (char)x;
            }
        }
        a.Dump();
    }

हाँ, अधिक LINQ प्यार! : D
१५

3

C # (और LINQ) 255 226 210 बाइट्स

पैट्रिक Huizinga की सलाह का उपयोग करते हुए, क्वेरी सिंटैक्स अब छोटा हो गया है:

namespace System.Linq{class P{static void Main(string[]a){Console.Write((from c in(a[0]+"ABCDEFGHIJKLMNOPQRSTUVWXYZ").ToUpper()where c>'@'&&c<'['group c by c into g orderby-g.Count()select g.Key).ToArray());}}}

स्पष्टीकरण:

Console.Write(
    (from c //declare our range variable
       in (a[0] + "ABCDEFGHIJKLMNOPQRSTUVWXYZ").ToUpper() //declare the datasource
     where c > '@' && c < '[' //include only letters
     group c by c into g //run of the mill group by
     orderby -g.Count() //order by descending
     select g.Key //we only want the actual letters
     ).ToArray() //mash it all into an array
  );

समतुल्य विधि वाक्यविन्यास (217):

namespace System.Linq{class P{static void Main(string[]a){Console.Write((a[0]+"ABCDEFGHIJKLMNOPQRSTUVWXYZ").ToUpper().GroupBy(c=>c).OrderBy(c=>-c.Count()).Where(c=>c.Key>'@'&&c.Key<'[').Select(c=>c.Key).ToArray());}}}

मूल पोस्ट:

namespace System.Linq{class P{static void Main(string[]a){(a[0]+"ABCDEFGHIJKLMNOPQRSTUVWXYZ").ToUpper().GroupBy(c=>c).OrderByDescending(c=>c.Count()).Where(c=>c.Key>'@'&&c.Key<'[').ToList().ForEach(c=>Console.Write(c.Key));}}}

यह मेरा पहला सबमिशन है और मुझे काम पर काम करना चाहिए लेकिन यह सिर्फ इतना मजेदार लग रहा था क्योंकि मुझे ऐसा लग रहा था कि मैं वास्तव में एक बार भाग ले सकता हूं।

स्पष्टीकरण:

(a[0] + "ABCDEFGHIJKLMNOPQRSTUVWXYZ") //ensure each character appears once
  .ToUpper()
  .GroupBy(c => c) //get access to .Count()
  .OrderByDescending(c => c.Count())
  .Where(c => c.Key > '@' && c.Key < '[') //exclude anything other than letters
  .ToList() //Only lists have a .ForEach() :(
  .ForEach(c => Console.Write(c.Key)); //print output

मैं LINQ के लिए कभी भी सिंटैक्स का उपयोग नहीं करता हूं, इसलिए यह मेरे लिए एक सीखने का अनुभव था :) इसके बारे में भी सोचता हूं कि अब मैं अक्षर बाइट्स को उनके पूर्णांक समकक्षों के साथ बदलकर 2 बाइट्स बचा सकता हूं, लेकिन, meh।

ProgramFOX और न्यूम लॉक से युक्तियों के लिए संक्षिप्त धन्यवाद :)

बराबर क्वेरी सिंटैक्स (थोड़ा लंबा):

(from c in (a[0]+"ABCDEFGHIJKLMNOPQRSTUVWXYZ").ToUpper() where c>'@'&&c<'[' group c by c into g orderby g.Count() descending select g.Key).ToList().ForEach(c=>Console.Write(c));

1
एक पहले देखो पर, आप अपने वर्ग नामकरण बस के आधार पर पात्रों का एक बहुत बचा सकता है Pके बजाय Programऔर string[]aके बजाय string[] argsऔर c=>...के बजाय (c)=>...
अंक लॉक

दो usingबयानों के बजाय , आप अपनी कक्षा को System.Linqनाम स्थान के अंदर रख सकते हैं , और बयानों का उपयोग करके दोनों को हटा सकते हैं। तब आप कुछ पात्रों को बचा सकते हैं और यह अभी भी ठीक काम करेगा।
प्रोग्रामफॉक्स

@NumLock राइट, उस के बारे में भी नहीं सोचा था :) @ProgramFOX है कि मुझे कुछ भी नहीं बचा है क्योंकि namespaceअब से अधिक है usingऔर दो अतिरिक्त {}एस मुझे और अधिक लागत आएगी।
ldam

1
namespace System.Linq{}यह देखने से ही स्पष्ट रूप से कम है using System;using System.Linq;। विचार दोनों को usingपूरी तरह से छोड़ देना है ।
न्यूम लॉक

आह हाँ, यह दोनों को हटा देता है, तुम सही हो, मैं सोच रहा था कि यह केवल हटा दिया। धन्यवाद।
लड्डू

3

सी ++ 701 322 232 बाइट्स

पहला संस्करण 701 बाइट्स (मुहावरेदार एसटीएल उपयोग)

#define _HAS_TRADITIONAL_STL 1
#include <numeric>
#include <iostream>
#include <iterator>
#include <string>
#include <algorithm>
#include <functional>
#include <map>
#include <set>
#define ALL(x) x.begin(), x.end()
using namespace std;
typedef istream_iterator<char> iic;typedef pair<int, char> pic;map<char, int> c;set<pic> d;
void f1(char x) {c[x]--;}
void f2(const pic &p) {d.insert(make_pair(p.second, p.first));}
int main(){string s(26, 0);stdext::iota(ALL(s), 65);copy(ALL(s), ostream_iterator<char>(cout));transform(iic(cin), iic(), back_inserter(s), toupper);for_each(ALL(s), f1);for_each(ALL(c), f2);transform(ALL(c2), ostream_iterator<char>(cout), select2nd<pic>());}

विस्तारित स्वच्छ संस्करण:

#define _HAS_TRADITIONAL_STL 1
#include <numeric>
#include <iostream>
#include <iterator>
#include <string>
#include <algorithm>
#include <functional>
#include <map>
#include <set>
using namespace std;

typedef istream_iterator<char> iic;
map<char, int> counts;
set<pair<int, char> > counts2;

void docount(char ch) { counts[ch]--; }
void toCounts2(const pair<char, int> &p) { counts2.insert(make_pair(p.second, p.first)); }

int main()
{
    string s(26, 0);
    stdext::iota(s.begin(), s.end(), 65);
    transform(iic(cin), iic(), back_inserter(s), toupper);
    for_each(s.begin(), s.end(), docount);
    for_each(counts.begin(), counts.end(), toCounts2);
    transform(counts2.begin(), counts2.end(), ostream_iterator<char>(cout), select2nd< pair<int, char> >());
}

विचार बिना किसी हैक के "उचित" C ++ प्रोग्राम को प्रदर्शित करना है। बॉयलरप्लेट और इस तथ्य को अनदेखा करें कि यह केवल वीसी ++ पर संकलित है

स्पष्टीकरण:

हम A से Z को iota () के साथ एक स्ट्रिंग में भरते हैं , यह सुनिश्चित करता है कि जब हम घटनाओं को गिनते हैं, तो प्रत्येक वर्ण प्रकट होता है भले ही वह इनपुट में न हो।

रूपांतर () मानक इनपुट से चरित्र द्वारा वर्ण की प्रतिलिपि बनाता है और हर एक पर टॉपर () को कॉल करने के बाद इसे एस के अंत में डालता है

मानचित्र में प्रत्येक वर्ण की गिनती को घटाया गया है (नकारात्मक गणनाओं को बनाए रखते हुए हम बिना अतिरिक्त कोड के अवरोही हो सकते हैं)

काउंट मैप एंट्रीज को जोड़े के एक सेट, स्वैपिंग (चार, काउंट) टू (काउंट, चार) में कॉपी किया जाता है। चूंकि सेट का आदेश दिया जाता है, हम उन्हें आवृत्ति की संख्या में कमी करके क्रमबद्ध करते हैं

अंत में हम सेट की सामग्री को मानक रूप में कॉपी करते हैं, ट्रांसफॉर्मेशन का उपयोग करते हुए, और select2nd () का उपयोग करते हुए जोड़ी के केवल दूसरे सदस्य को चुनने के लिए ।

कोड काफी पठनीय है। एक C ++ 11 समाधान बहुत सुंदर लगेगा, क्योंकि हम लैम्ब्डा का उपयोग कर सकते हैं

C ++ 11 संस्करण - लैंबडास की कोई आवश्यकता नहीं है, लेकिन चीजों को बहुत साफ करने के लिए ऑटो और रेंज आधारित है (यह सोचने के लिए कि आप नियमित C ++ 98 के साथ बहुत समान कर सकते हैं)

#include<iostream>
#include<iterator>
#include<map>
#include<set>
using namespace std;int main(){istream_iterator<char> b(cin),e;map<char,int> c;set<pair<int,char>> d;for(char i='A';i<='Z';++i){--c[i];}for(auto i=b;i!=e;++i){c[toupper(*i)]--;}for(auto p:c){d.insert(make_pair(p.second,p.first));}for(auto p:d){cout<<p.second;}}

विस्तारित संस्करण:

#include <iostream>
#include <iterator>
#include <map>
#include <set>
using namespace std;
int main()
{
    istream_iterator<char> b(cin), e;
    map<char, int> c;
    set<pair<int, char>> d;
    for(char i = 'A'; i <= 'Z'; ++i) {--c[i];}
    for(auto i = b; i != e; ++i) {c[toupper(*i)]--;}
    for(auto p : c) { d.insert(make_pair(p.second, p.first)); }
    for(auto p : d) { cout << p.second; }
}

अगला पुनरावृत्ति (हम क्यों argv है जब स्टड से पढ़ें):

#include <set>
#include <iostream>
int c[256];int main(int n, char **s){std::set<std::pair<int,char>> d;while(*s[1]){c[toupper(*s[1]++)]--;}for(n=65;n<92;++n){d.insert(std::make_pair(--c[n],n));}for(auto p:d){std::cout<<p.second;}}

विस्तारित संस्करण:

#include <set>
#include <iostream>
int c[256];
int main(int n, char **s)
{
    std::set<std::pair<int, char>> d;
    while (*s[1])
    {
        c[toupper(*s[1]++)]--;
    }
    for (n = 65; n < 92; n++)
    {
        d.insert(std::make_pair(--c[n], n));
    }
    for (auto p : d)
    {
        std::cout << p.second;
    }
}

3

जेली , 9 बाइट्स (गैर-प्रतिस्पर्धात्मक)

ØAŒuċ¥@ÞU

व्याख्या

ØAŒuċ¥@ÞU  Main Link
       Þ   Sort
ØA         The uppercase alphabet by
  Œuċ¥@    number of occurrences in the input:
  Œu       Uppercase
    ċ      Count occurrences
     ¥     Grammar: Last two links as a dyad
      @    Swap arguments
        U  Reverse (because sort sorts up)

यह पढ़ता है "इनपुट अपरकेस, उलट की घटनाओं की संख्या द्वारा अपरकेस वर्णमाला को क्रमबद्ध करें", जो चुनौती का एक बहुत शाब्दिक अनुवाद है: पी

इसे ऑनलाइन आज़माएं!

यह चुनौती जेली हाइपरट्रेनिंग से जुड़ी थी जहां हमने चुनौती को हल किया। मैंने इसे पोस्ट किया क्योंकि मैं 10 बाइट्स तक पहुंचने वाला पहला व्यक्ति था।

-1 बाइट की बदौलत एरिक द आउटगोलर (JHT शिक्षक)


9 बाइट्स:ØAŒuċ¥@ÞU
आउटगोल्फर

@EriktheOutgolfer ओह कूल, धन्यवाद!
हाइपरएन्यूट्रीनो

2

सी ++ 377

कमांड लाइन के माध्यम से सरणी ए में वर्णमाला को सॉर्ट करने के लिए सरणी n में अक्षर काउंट का उपयोग करते हुए इम्प्लांटेशन qsort: golf.exe < in.txt

int n[26],c,k,N;
char A[26];
int C(const void*a,const void*b)
{
int i=(int)(*(char*)a -'A');
int j=(int)(*(char*)b -'A');
return n[j]-n[i];
}
int main()
{
for(;k<26;k++)
{
A[k]=k+'A';
}
N=sizeof(A);
c=getchar();
while(c>0)
{
c=toupper(c);
c=c-'A';
if(c>=0&&c<26)n[c]++;
c=getchar();
}
qsort(A,N,1,C);
for(k=0;k<N;k++)
{
putchar(A[k]);
}
return 0;
}

2

सी, 117 (119) बाइट्स

x[256];m=1;char c;main(){while(c=getchar()+1)++x[c-1&95];for(;m=x[++c]<x[m]?m:c;x[m<65|m>90||c?m*!c:putchar(m)]=-1);}
  • ASCII कोड> = 128 वाले कुछ इनपुट गलत रूप से पत्र आवृत्तियों को बढ़ाएंगे। इसे ठीक करने के लिए, स्थिरांक को बदलें95223 , 1 अतिरिक्त बाइट की कीमत पर साथ ।
  • यह ASCII कोड 255 के साथ चरित्र वाले इनपुट पर जल्दी समाप्त हो जाएगा। 1 अतिरिक्त बाइट की कीमत पर इसे ठीक करने के लिए, char c;बस c;और इसके ++cलिए बदलें c=c+1%255

2

पॉवरशेल - 139 वर्ण

पहला, मैं पॉवरशेल विशेषज्ञ नहीं हूं। बहुत यकीन है कि इससे छोटे हैं। लेकिन इससे खुश था और साझा करने का फैसला किया।

$a = Read-host
$b = ($a.ToUpper() -replace '[^A-Z]','').ToCharArray() + (65..90|%{[char[]]$_})|Group|sort Count -desc|%{$_.Name}
-join $b

यह काम किस प्रकार करता है:

$a = Read-host            # read from stdin and save into a string var $a
$a.ToUpper()              # Convert the string to UPPERCASE
-replace'[^A-Z]',''       # Remove all non A-Z characters from the str
(...).ToCharArray()       # Convert the inner object (string) to a Char Array
+  (65..90|%{[char[]]$_}) # Create another char array with A-Z chars expanded, 
                          #  and append it to the previous one.
|Group                    # Group the char array by value for each element, 
                          #  consolidates them and count each char occurrence. Example:
                          #  Count | Name
                          #  ----- | -----
                          #      4 | B
                          #      1 | F
                          #      2 | C 
                          #     .. | ..
                          # 
|sort Count -desc         # Sorts the previous hash-table by the 'Count' column 
                          #   in desc ordering
|%{$_.Name}               # Grab only the 'Name' column from the previous sorted hash-table. 
                          # The retuslt obj will be a simple char array again, 
                          #   with the letters in the desired order
$b = (...)                # Saves the resulting char array into a new variable $b
-join $b                  # join the resulting char array elements into a single 
                          #   string, and print it to stdout. 


2

एपीएल, २६ २० अक्षर

⎕a[⍒+/⎕a∘.=('\w'⎕r'\u0')⍞]

⎕a[⍒+/⎕a∘.=1(819⌶)⍞]

-6 एडम के लिए धन्यवाद।


1
('\w'⎕r'\u0')1(819⌶)
आदम
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.