একটি প্রাকৃতিক লগ উপর পিঁপড়া


23

এটি একটি ভাল শিক্ষানবিস চ্যালেঞ্জ এবং একটি ভাল সময় ঘাতক।

আমি কেবল একটি প্রাকৃতিক-লগ বলেছিলাম কারণ শিরোনামটি খুব ছোট ছিল, লগারিদমের সাথে এর কোনও যোগসূত্র নেই।

দেওয়া 2 ভেরিয়েবল:

  • পিঁপড়ার সংখ্যা n
  • লগ প্রস্থ w

আউটপুট প্রস্থ একটি লগ wসঙ্গে nবীজে পিঁপড়ে না ধরতে (উদাহরণ দেখানো w=3, n=6)

|             |
| \O/ \O/ \O/ |
| -O- -O- -O- |
| /o\ /o\ /o\ |
|  ^   ^   ^  |
|             |
| \O/ \O/ \O/ |
| -O- -O- -O- |
| /o\ /o\ /o\ |
|  ^   ^   ^  |
|             |

একক পিঁপড়ের মতো দেখতে:

\O/ # Upper-case O
-O- # Upper-case O
/o\ # Lower-case o
 ^  

কয়েকটি পিঁপড়া আইন:

  1. পিঁপড়াগুলি একে অপরকে বা লগের প্রান্তটি সরাসরি স্পর্শ করতে পারে না, তারা স্পেসগুলি স্পর্শ করতে পছন্দ করে।
  2. পিঁপড়ার প্রতিটি সারি wপ্রশস্ত হতে হবে n/w, পিঁপড়ার সারি সহ ।
  3. পিঁপড়ার সর্বদা একটি লগ প্রয়োজন, লগ প্রস্থ 0 এর চেয়ে বড়, গ্যারান্টিযুক্ত।
  4. পিঁপড়াগুলিও ... ভাল, পিঁপড়ার দরকার, পিঁপড়ার সংখ্যা 0 এর চেয়ে বেশি, গ্যারান্টিযুক্ত।
  5. পিঁপড়াগুলিও আশ্চর্যজনকভাবে সুসংহত, তারা বাম থেকে ডানে, উপরে থেকে নীচে একটি লগ পূরণ করবে; যেন তারা কোনও বই পড়ছে।

অ্যান্ট-xamples

ডাব্লু = 3, এন = 5

|             |
| \O/ \O/ \O/ |
| -O- -O- -O- |
| /o\ /o\ /o\ |
|  ^   ^   ^  |
|             |
| \O/ \O/     |
| -O- -O-     |
| /o\ /o\     |
|  ^   ^      |
|             |

ডাব্লু = 1, এন = 1

|     |
| \O/ |
| -O- |
| /o\ |
|  ^  |
|     |

ডাব্লু = 1, এন = 3

|     |
| \O/ |
| -O- |
| /o\ |
|  ^  |
|     |
| \O/ |
| -O- |
| /o\ |
|  ^  |
|     |
| \O/ |
| -O- |
| /o\ |
|  ^  |
|     |

এটি , ক্ষুদ্রতম বাইটকাউন্টের সাথে জয়যুক্ত ব্যক্তি।



@ অ্যাডমবার্কবার্ক আমি এখন মনে আছে। আমি এটি দিয়ে অর্ধেক হয়ে গেলাম এবং অনুমানটি ভুলভাবে লিখলাম, অবচেতনভাবে সেই ধারণার কিছু অংশ চুরি করেছে।
যাদু অক্টোপাস উরান

এগুলি পিঁপড়ের ওয়াই-লগগুলি।
অর্জুন

"পিঁপড়ার প্রতিটি সারি অবশ্যই প্রশস্ত প্রশস্ত" " w>nডান হাতের আগে যদি অতিরিক্ত জায়গা থাকা উচিত |বা না হয়, বা এটি আমাদের উপর নির্ভর করে?
জোনাথন অ্যালান

1
-1 এর জন্য Ant-xamples(আমি
পাঞ্জাগুলি

উত্তর:


4

জেলি ,  44  43 বাইট

ক্রস করা হয়েছে 44 এর ব্যবহারের সাথে 44 নয়  

⁶ṁ;⁶jЀ“\-/“OOo^ ”;UṖz⁶¤Y
sÇ€⁶;YỴz⁶Zj@€⁾||Y

এটি অনলাইন চেষ্টা করুন!

কিভাবে?

⁶ṁ;⁶jЀ“\-/“OOo^ ”;UṖz⁶¤Y - Link 1, make a row of ants: list x (could be integer = length)
⁶                         - literal ' '
 ṁ                        - mould like x (makes a list of that many spaces)
  ;⁶                      - concatenate one more space
                       ¤  - nilad followed by link(s) as a nilad
       “\-/“OOo^ ”        -   literal      ["\-/","OOo^ "] ("..." a list of chars really)
                   U      -   reverse each [" ^oOO","/-\"]
                  ;       -   concatenate  ["\-/","OOo^ "," ^oOO","/-\"]
                    Ṗ     -   pop          ["\-/","OOo^ "," ^oOO"]
                      ⁶   -   literal ' '
                     z    -   transpose & fill ["\O/","-O-","/o\"," ^ ","   "]
    jЀ                   - join left mapped over right
                          -   (join the spaces with each of the ant parts in turn)
                        Y - join with newlines

sÇ€⁶;YỴz⁶Zj@€⁾||Y - Main link: n, w
s                 - split n into chunks of length w (implicitly makes a range of length n)
 Ç€               - call the last link (1) as a monad for €ach
   ⁶;             - a space concatenated with that
     Y            - join with newlines
      Ỵ           - split at newlines (both the ones we just joined with AND the others!)
       z⁶         - transpose & fill with space characters (making the shorter rows,
                  -   including the single space as long as the longest one)
         Z        - transpose it back the right way
             ⁾||  - literal ['|','|']
          j@€     - join with reverse arguments for €ach (put each row between pipes)
                Y - join back up with newlines
                  - implicit print

আমি জিজ্ঞেস করেছি w<nযে একটি মন্তব্য যেহেতু এটি সামান্য দ্ব্যর্থক আছে।
যদি লগের wপিঁপড়াগুলি প্রশস্ত হওয়ার পরিবর্তে পিঁপড়া প্রশস্ত হওয়া দরকার হয় wতবে এর জন্য দুটি বাইট খরচ হয়:

⁶ṁ;⁶jЀ“\-/“OOo^ ”;UṖz⁶¤Y
+RsÇ€YỴz⁶Zj@€⁾||ṫ5Y

এটি প্রথম, ফাঁকা রেখা তৈরির জন্য কোনও একক স্থানের প্রিপেন্ডিংয়ের পরিবর্তে আগের মতোই কাজ করে এটি পিঁপড়ার একটি সম্পূর্ণ অতিরিক্ত সারি তৈরি করে এবং এর পিছনে ফাঁকা রেখা বাদে সমস্ত ছাড়িয়ে যায়।


5

ভি , 70 , 68 বাইট

i \O/ 
 -O- 
 /o\ 
  ^  Àä{ò@bf }C GïpòÇÓ/d
HÄÒ çÞ/ÙÒ 
ëI|yê$p

এটি অনলাইন চেষ্টা করুন!

00000000: 6920 5c4f 2f20 0a20 2d4f 2d20 0a20 2f6f  i \O/ . -O- . /o
00000010: 5c20 0a20 205e 2020 1bc0 e416 7bf2 4062  \ .  ^  ....{.@b
00000020: 6620 167d 4320 1b47 ef70 f2c7 d32f 640a  f .}C .G.p.../d.
00000030: 48c4 d220 e7de 2fd9 d220 0a16 eb49 7c1b  H.. ../.. ...I|.
00000040: 79ea 2470                                y.$p

আমার সাথে এর আগে কখনও ঘটেনি, তবে একটি পরিচিত বাগ আসলে আমাকে বাইটস বাঁচিয়েছে!

কী চলছে তা সঠিকভাবে ব্যাখ্যা করা খুব কষ্টকর, তবে দুর্ভাগ্যক্রমে আপনি যখন কলামগুলি দ্বারা কোনও সদৃশ করার চেষ্টা করবেন, ভি ডুপ্লিকেট করার আগে একটি কলামটি সরিয়ে নিয়ে যাবে। মূলত আমি তাই করেছি:

h<C-v>{dÀp

যা সদৃশ অপারেটর ব্যবহার করে না। তবে, যেহেতু আমাদের ইতিমধ্যে একটি লাইন ওভার সরানোর দরকার ছিল, আমরা কেবল তা করতে পারি

hÀä<C-v>{

নিস! বাগ শোষণের সম্ভাব্য মনোনয়ন: পি।
যাদু অক্টোপাস উরন

5

পিএইচপি> = 7.1, 150 বাইট

for([,$w,$n]=$argv;$i<ceil($n/$w)*5+1;)echo str_pad("| ".str_repeat(["","\O/ ","-O- ","/o\ "," ^  "][$i%5],$n<$w*ceil($i++/5)?$n%$w:$w),$w*4+2)."|\n";

অনলাইন সংস্করণ


"অনলাইন সংস্করণ" এবং "কোড সম্পাদন করুন" ক্লিক করার সময় আমি ত্রুটি পেয়েছি।
কেজেটিল এস

1
@KjetilS। পিএইচপি সংস্করণ 7.1
জার্গ হালসারম্যান

হ্যাঁ, 7.1 ঠিক আছে।
কেজেটিল এস

5

পাইথন 2, 144 বাইট

n,w=input()
s=' ';k='|';a=k+s*w*4+s+k;print a
while n>0:
 for i in['\\O/','-O-','/o\\',' ^ ']:print k+s+(i+s)*min(w,n)+s*4*(w-n)+k
 n-=w;print a

অনলাইনে চেষ্টা করে দেখুন!


যেমন পিঁপড়া মধ্যে খালি লাইন (তুলনা উদাহরণ ব্যার্থ এই অবৈধ w=1n=3আপনার সংস্করণে)।
ফ্যাটালমার্লিন

@ ফ্যাটালমার্লিন ধন্যবাদ! স্থির :)
গণিত জাঙ্কি

4

05 এ বি 1 ই , 47 বাইট

"   \O/-O-/o\ ^ "5äðìI.D)IôvyøJ'|ì})˜¬¸«.B„ |«»

এটি অনলাইন চেষ্টা করুন!

ব্যাখ্যা

"   \O/-O-/o\ ^ "                                # push the ant-string
                 5ä                              # split into 5 parts
                   ðì                            # prepend a space to each
                     I.D                         # copy input-1 number of times
                        )                        # wrap in a list
                         Iô                      # split into parts each the size of input-2
                           v                     # for each row of ants
                            yø                   # zip, so body parts are on the same row
                              J'|ì               # join to string and prepend a pipe to each
                                  }              # end loop
                                   )˜            # wrap in a flattened list
                                     ¬¸«         # append a copy of the first row (spaces)
                                        .B       # pad rows to equal length with spaces
                                          „ |«   # append " |" to each row
                                              »  # merge on newlines

4

SOGL , 74 71 74 বাইট

 |pe4*I@*o |o→L:"╔O¦‘2n;"nΤ↕¬┐α┐PΝld‘*┼eG-’⁵@**┼ |4*┼OL→ALbe÷:?{eA}}be%:?A

প্রথম অংশ: ফাংশন যা খালি লগ অংশকে আউটপুট করে

             →L  define function L
 |p              output in a newline "|"
   e4*           multiply width by 4
      I          increace that
       @*        get that many spaces
         o       append [to current line] that
           |o    append "|"

দ্বিতীয় অংশে একটি সংকুচিত স্ট্রিং রয়েছে "nΤ↕¬┐α┐PΝld‘, যা পিপীলিকা। এটি decompresses \-/ OOo^/-\ । এটাই পিপড়া (ডানদিকে ফাঁকা রেখে) তবে উপরে থেকে নীচে নেমে ডান মতো পছন্দ করে নেওয়া

159d
26ae
37bf
48cg

এটি এর মতো সঞ্চিত কারণ ফাংশনটি এর মতো স্ট্রিংগুলিকে সংযোজন করে (কারণ এর পরে আপনি এতে স্ট্রিংকে একাধিক উদাহরণ যুক্ত করতে গুণতে পারেন)। অংশটি নিজেই: ফাংশন যা কয়টি পিঁপড়া আঁকতে হবে তা বোঝাতে স্ট্যাকের জন্য একটি সংখ্যার জন্য জিজ্ঞাসা করে।

                                    Example input: width 3, on stack 2
:                                   duplicate the input                             [2,2]
 "╔O¦‘                              push "| | | | "                                 [2,2,"| | | | "]
      2n                            split into chunks of two                        [2,2,["| ","| ","| ","| "]]
        ;                           put one of the input copies ontop of the stack  [2,["| ","| ","| ","| "], 2]
         "...‘*                     multiply that many ants                         [2,["| ","| ","| ","| "], "\\-/ OOo^/-\\     \\-/ OOo^/-\\     "]
               ┼                    add horizontally the ants                       ["| \O/ \O/ \O/ ",
                                                                                     "| -O- -O- -O- ",
                                                                                     "| /o\ /o\ /o\ ",
                                                                                     "|  ^   ^   ^  "]
                e                   get the width                                   [["| \\O/ \\O/ \\O/ ", "| -O- -O- -O- ", "| /o\\ /o\\ /o\\ ", "|  ^   ^   ^  "], 3]
                 G-                 subtract input from it                          [["| \\O/ \\O/ \\O/ ", "| -O- -O- -O- ", "| /o\\ /o\\ /o\\ ", "|  ^   ^   ^  "], 1]
                   ’⁵@*             push 16 spaces                                  [["| \\O/ \\O/ \\O/ ", "| -O- -O- -O- ", "| /o\\ /o\\ /o\\ ", "|  ^   ^   ^  "], 1, "                "]
                       *            multiply [the 16 spaces and empty place count]  [["| \\O/ \\O/ \\O/ ", "| -O- -O- -O- ", "| /o\\ /o\\ /o\\ ", "|  ^   ^   ^  "], "                "]
                        ┼           add that horizontally                           [["| \\O/ \\O/ \\O/     ", "| -O- -O- -O-     ", "| /o\\ /o\\ /o\\     ", "|  ^   ^   ^      "]]
                          |4*┼      add 4 vertical bars to the array                [["| \\O/ \\O/ \\O/     |", "| -O- -O- -O-     |", "| /o\\ /o\\ /o\\     |", "|  ^   ^   ^      |"]]
                              O     output the array                                []
                               L    call the empty line function                    []
                                →A  define as A

এবং প্রধান কাজ:

L                  call the empty line drawing function
 be÷               push floor(b/e) (the amount of full lines)
    :?{eA}}        that many times call A with the full width on the stack
           be%     push b%e (the leftovers)
              :?   if truthy (aka !=0)
                A   call A with for the leftovers

2

পার্ল 5 , 159 বাইট

($w,$n)=@ARGV;
print
$_%$w?"":"| ",
['   \O/-O-/o\\ ^ '=~/.../g]->[($_<5*$w*int$n/$w||$_%$w<$n%$w?$_/$w:0)%5],
($_+1)%$w?" ":" |\n"
for 0..$w*(6+5*int(($n-1)/$w))-1

এটি অনলাইন চেষ্টা করুন!

পার্ল 5 , 152 বাইট

পাইথন সমাধানের ভিত্তিতে আর একটি:

($w,$n)=@ARGV;
$b=' 'x($w*4+1);$j=$a="|\n|";
map$j.=' '."$_ "x($w<$n?$w:$n).'    'x($w-$n).$a,'\\O/','-O-','/o\\',' ^ 'and$n-=$w
while$n>0;
print"|$b$j$b|"

এটি অনলাইন চেষ্টা করুন!


0

গণিত 210 বাইট

StringRiffle[If[#2==c||#2==1,"|",If[r-#1<6&&#2>2+4 (a+w-h w),Table[" ",5,4],Characters@"    \\O/ -O- /o\\  ^  "~Partition~4][[1+Mod[#1-1,5],1+Mod[#2+1,4]]]]&~Array~{r=5(h=⌈(a=#)/(w=#2)⌉)+1,c=4w+3},"\n",""]&

ভাবছেন আমার গাণিতিক ভিত্তিক গল্ফিং ভাষা করা উচিত।


0

পাইথন 2, 166 বাইট

w,n=input()
print'\n'.join(['|'+' '*w*4+' |']+[' '.join(['|']+[p]*r+['   ']*(w-r)+['|'])for r in[w]*(n/w)+[[],[n%w]][n%w>0] for p in['\O/','-O-','/o\\',' ^ ','   ']])

0

কাঠকয়লা , 43 বাইট

NθF⪪× Nθ«←P↓⁶M⊗⊕⊗θ→P↓⁶⸿E⪪\O/-O-/o\ ^ ³⭆ι⁺μκ

এটি অনলাইন চেষ্টা করুন! লিঙ্কটি কোডটির ভার্জোজ সংস্করণ। ব্যাখ্যা:

Nθ

ইনপুট w

F⪪× Nθ«

ইনপুট করুন n, তারপরে nস্পেসের একটি স্ট্রিং তৈরি করুন এবং এটিকে দৈর্ঘ্যের সারিগুলিতে বিভক্ত করুন w(শেষের অংশটি যা ছোট হতে পারে ব্যতীত)। এই সারিগুলির উপর লুপ করুন।

←P↓⁶M⊗⊕⊗θ→P↓⁶⸿

লগ বিভাগের পক্ষগুলি মুদ্রণ করুন।

  \O/-O-/o\ ^           Literal string
 ⪪            ³         Split into (4) pieces of length 3
E                       Map over each piece
               ⭆ι       Map over each row space
                 ⁺μκ    Appending the piece
                        Implicitly print the results on separate lines
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.