প্রত্যেকেরই বন্ধু থাকা উচিত


11

বিচ্ছিন্ন অক্ষর একটি অক্ষর (একটি নতুন লাইন ব্যতীত) যার একই ধরণের সংলগ্ন চরিত্র নেই। সংলগ্ন অক্ষরগুলি বাম দিকে, ডান উপরে বা নীচে হতে পারে তবে ত্রিভুজ নয়। উদাহরণস্বরূপ নীচের পাঠ্যটিতে Hবিচ্ছিন্ন:

Ybb
YH%
%%%%

অন্যান্য সমস্ত অক্ষর বিচ্ছিন্ন নয় কারণ তাদের প্রত্যেকেরই কমপক্ষে একই ধরণের সংলগ্ন অন্য একটি চরিত্র রয়েছে।

আপনার কাজটি এমন একটি প্রোগ্রাম লেখা যা ইনপুট হিসাবে স্ট্রিং নেয় এবং বিচ্ছিন্ন অক্ষরের সংখ্যা নির্ধারণ করে।

স্কোরিং

আপনার উত্তর দুটি মেট্রিক দ্বারা স্কোর করা হবে। প্রথমটি হল আপনার প্রোগ্রামে বিচ্ছিন্ন অক্ষরের সংখ্যা। এটি হ্রাস করার লক্ষ্য করা উচিত। দ্বিতীয়টি হবে আপনার প্রোগ্রামের বাইট সংখ্যা। আপনার এটিও হ্রাস করা উচিত। প্রোগ্রামের আকারটি প্রথম মানদণ্ডের জন্য টাই ব্রেকার হিসাবে কাজ করবে।

অতিরিক্ত বিধি

  • আপনার প্রোগ্রামে মুদ্রণযোগ্য আসকি রেঞ্জের সাথে সাথে কোনও অক্ষর ব্যবহারের ক্ষেত্রে আপনাকে ইনপুট সমর্থন করা উচিত।

  • আপনি লাইন বিরতিটিকে একটি নতুন লাইন চরিত্র বা লাইন ফিডের পরে একটি নতুন লাইন হিসাবে বিবেচনা করতে পারেন।

  • আপনি কোনও যুক্তিসঙ্গত বিন্যাসে ইনপুট নিতে পারেন। এটি লাইনের একটি তালিকা অন্তর্ভুক্ত।

পরীক্ষার কেস

Ybb
YH%
%%%%

1


Aaaab
uuu
yyybbb

2


A

1


qqWWaaww

0


2
একটি খালি স্ট্রিং বৈধ ইনপুট এবং যদি তাই হয় এটি 0 স্কোর? এছাড়াও ইনপুট টাইপটি কতটা নমনীয়? লাইন জরিমানা তালিকা?
ভেসকাঃ

নিউলাইনগুলি কি বিচ্ছিন্ন করা যায়?
জো কিং

1
@ ডিমচ্যাটজ কারণ এটির Yনীচে এটি রয়েছে।
এরিক আউটগলফার

1
প্রথম মেট্রিকের কোনও প্রোগ্রামিং ভাষায় পরিবেষ্টন করা যায় এবং প্রতিটি উত্তরের এখনই 0 স্কোর থাকে।
জিবি

1
@ জিবি আসলেই। আমি অনুমান করি যে এটির restricted-sourceপরিবর্তে চ্যালেঞ্জ হিসাবে রূপান্তরিত করতে এবং বিচ্ছিন্ন চরিত্রগুলি পুরোপুরি অস্বীকার করার জন্য খুব বেশি দেরি হয়নি ।
আর্নৌল্ড

উত্তর:


7

পাইথন 2 , 0 ( 350 344 314 309 301 298 291 বাইট)

def f(tt):11
def f(tt):
 tt=tt.split('\n')
 r =0#.split('\n')
#r  0#
#for
 for  ii,ll in enumerate(tt):
  for jj,cc in enumerate(ll):
##for+=1-(
    r+=1-(cc in ll[(jj or 2)-1:jj+2:2]    +''.join(ll[jj:
 jj+1]for ll in tt[(ii or 2)-1:ii+2:2]))##+''.join(ll[jj:
#  +1]for 
#print r
 print r
 

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

-7 বাইটস, জো কিংকে ধন্যবাদ



@ জোকিং ধন্যবাদ! :)
টিফিল্ড

5

পরিষ্কার , 0 ( 439 ... 415 বাইট)

-11 আরজান জোহানসেনকে ধন্যবাদ

পরিশেষে একটি চ্যালেঞ্জ যেখানে আমি ক্লিন দিয়ে 0 স্কোর করতে পারি!
(এবং সাধারণত উত্স-বিন্যাস চ্যালেঞ্জ এ খারাপ !)

//module 
  module d
import StdEnv,ArgEnv,Data.List,Data.Maybe
import StdEnv,ArgEnv,Data.List,Data.Maybe
Start=sum[1\\i<-l&v<-[0..],_<-i&u<-[0..]|all((<>)(?u v))[?(u-1)v,?(u+1)v,?u(v-1),?u(v+1)]]
Start=sum[1\\i<-l&v<-[0..],_<-i&u<-[0..]|all((<>)(?u v))[?(u-1)v,?(u+1)v,?u(v-1),?u(v+1)]] 
l=mklines[c\\c<-:getCommandLine.[1]]
l=mklines[c\\c<-:getCommandLine.[1]]
?x=mapMaybe(\k=k!?x)o(!?)l
?x=mapMaybe(\k=k!?x)o(!?)l

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

টিআইও লিঙ্কটি ক্লিনটি টিআইওতে module mainযেভাবে প্রয়োগ করা হয়েছে তার কারণে এটি ব্যবহার করে তবে টিআইওর পরিবর্তে module dআপনি ফাইলটির নাম দিলে কাজ করবে ।d.iclmain.icl

পুরানো একটি লাইন ব্যাখ্যা করা হয়েছে (নতুন সংস্করণটি ভিন্ন ক্রমে একই জিনিস):

Start                                       // entry point
 = let                                      // define locals
  l = mklines                               // `l` is argument split at newlines
   [c \\ c <-: getCommandLine.[1]];         // the second command-line arg turned into a [Char]
  ? x y                                     // function ? of coordinate (x,y)
   = mapMaybe                               // if the argument isn't Nothing
    (\k = k!?x)                             // try taking the `x`-th index
    (l!?y)                                  // of the `y`-th index of `l`
  in                                        // in the context of
   sum [                                    // the sum of
    1                                       // the integer one
    \\ i <- l & v <- [0..]                  // for every index in `l`
    , _ <- i & u <- [0..]                   // for every subindex in `l`
    | all (                                 // where all of the second argument
      (<>)(?u v)                            // doesn't equal the first argument
     ) [?(u-1)v, ?(u+1)v, ?u(v-1), ?u(v+1)] // over every adjacent element
   ]


@ আরজান জোহানসেন ধন্যবাদ! আমিও মডিউল হেডার পরিবর্তন যেহেতু আমরা একটি নিকটবর্তী আছে dকুশলী
Οurous

5

জাভাস্ক্রিপ্ট (ES6), 0 (154 বাইট)

সংরক্ষিত 2 4 @ ØrjanJohansen ধন্যবাদ বাইট

স্ট্রিংগুলির অ্যারে হিসাবে ইনপুট নেয়।

s  =>
s//=>(s,y,a
.map((s,y,a)=>[...s]
.map((c,x  )=>[...s]
&&//++c,x
 s[x+1]==c|
 s[x-1]==c|
(a[y-1]||0)[x]==c|
(a[y+1]||0)[x]==c||
  i++),i=0)
&&i//),i=

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



4

জেলি , 0 ( 41 27 25 বাইট)

ŒĠạþ`€Ẏ§CẠ€S
ŒĠạþ`€Ẏ§CẠ€S

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

লাইনের তালিকা হিসাবে ইনপুট নেয়। কোডের প্রথম লাইনটি কখনই কিছু করে না এবং কেবল বিচ্ছিন্ন অক্ষরগুলি হ্রাস করতে পারে।

ỴŒĠạþ`€Ẏ§1eⱮCS
Ỵ                 Split the text on newlines.
 ŒĠ               Group the multidimensional indices by their value.
      €           For each list of indices:
   ạ                Take the absolute difference...
    þ`              ...between each pair.
       Ẏ          Concatenate the lists of differences.
        §         Sum the x & y differences. This computes the Manhattan distance.
                  At this point we have a list for each character in the text of 
                  Manhattan distances between it and it's identical characters. 
         1eⱮ      Is there a 1 in each of the lists? None for isolated characters.
            C     Complement: 0 <-> 1.
             S    Sum. Counts the isolated characters

3

এমএটিএল , 0 (54 বাইট)

TTTTf"Go@X!0JQJ&(d@_X!]***ggss
%%%%f"Go@X!0JQJ&(d@_X!]

ইনপুট স্ট্রিং একটি সেল অ্যারে, প্রতিটি লাইন জন্য এগুলির মধ্যে একটি: {'line 1', 'line 2', 'and line 3'}

এটি অনলাইন চেষ্টা করুন! অথবা পরীক্ষার কেস এবং উত্স কোড যাচাই করুন



1

05 এ বি 1 , 0 (101 বাইট )

žGçU|€SXζζD"εγεDgDisëXи]"©.V˜sø®.V€Sø˜‚øʒË}ʒXå≠}gq
žGçU|€SXζζD"εγεDgDisëXи]"©.V˜sø®.V€Sø˜‚øʒË}ʒXå≠}gq

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

এটি আমি এখনও লিখেছি এমন এক কুরুচিপূর্ণ এবং দীর্ঘতম 05AB1E প্রোগ্রাম ..>>> এই চ্যালেঞ্জটি 05AB1E এ প্রতারণামূলকভাবে কঠোর। আমার কোনও সন্দেহ নেই যে বাইট-কাউন্টটি কমপক্ষে অর্ধেক বা এমনকি তিন / চারগুণ ছোট হতে পারে ভিন্ন পদ্ধতির (বা এমনকি একই ধরণের পদ্ধতির সাহায্যে) ব্যবহার করে, তবে বর্তমানে কীভাবে তা দেখছি না। আমি এই মুহুর্তে এখনই কাজ করছি বলে খুব আনন্দিত .. অন্য কেউ যদি কিছু স্মার্ট ট্রিকস দিয়ে খুব কম 05ab1E উত্তর পোস্ট করেন তবে আমি সম্ভবত উত্তরটি লজ্জার কারণে মুছে ফেলব ... xD

ব্যাখ্যা:

žGç                # Character with unicode 32768 ('耀')
   U               # Pop and store it in variable `X`
                   # (This character is not part of the printable ASCII, nor of my 05AB1E code)
|                  # Take the multi-line input as list
                   #  i.e. "Ybb\nYH%\n%%%%" → ["Ybb","YH%","%%%%"]
 S                # Convert each string to a list of characters
                   #  i.e. ["Ybb","YH%","%%%%"] → [["Y","b","b"],["Y","H","%"],["%","%","%","%"]]
   Xζζ             # Zip with character `X` as filler twice to make the lines of equal length
                   #  i.e. [["Y","b","b"],["Y","H","%"],["%","%","%","%"]]
                   #   → [["Y","b","b","耀"],["Y","H","%","耀"],["%","%","%","%"]]
      D            # Duplicate this list
"             "    # Create a string
               ©   # Which we store in the register (without popping)
                .V # And execute that string as 05AB1E code
 ε                 #  Map each inner list to:
  γ                #   Split in chunks of the same characters
                   #    i.e. [["Y","b","b"],["Y","H","%"],["%","%","%","%"]]
                   #     → [[["Y"],["b","b"]],[["Y"],["H"],["%"]],[["%","%","%","%"]]]
   ε               #   Map each of those to:
    D              #    Duplicate the current inner list
     gDi           #    If its length is exactly 1:
        s          #     Swap so the mapping keeps the duplicated single character (as list)
       ë           #    Else:
        Xи         #     Take character `X` repeated the length amount of times
                   #      i.e. ["%","%","%","%"] (length 4) → ["耀","耀","耀","耀"]
          ]        #  Close the if-else and both maps
           ˜       #  Flatten the list to a single list of characters
                   #   i.e. [[["Y"],["耀","耀"],["耀"]],[["Y"],["H"],["%"],["耀"]],[["耀","耀","耀","耀"]]]
                   #    → ["Y","耀","耀","耀","Y","H","%","耀","耀","耀","耀","耀"]
s                  # Swap so the duplicate list is at the top of the stack
 ø                 # Swap its rows and columns
                   #  i.e. [["Y","b","b","耀"],["Y","H","%","耀"],["%","%","%","%"]]
                   #   → [["Y","Y","%"],["b","H","%"],["b","%","%"],["耀","耀","%"]]
  ®.V              # Execute the same piece of code again that we've stored in the register
     S            # Convert each to a list of characters
                   #  i.e. [[["耀","耀"],["%"]],[["b"],["H"],["%"]],[["b"],["耀","耀"]],[["耀","耀"],["%"]]]
                   #   → [["耀","耀","%"],["b","H","%"],["b","耀","耀"],["耀","耀","%"]]
       ø           # Swap its rows and columns back again
                   #  i.e. [["耀","b","b","耀"],["耀","H","耀","耀"],["%","%","耀","%"]]
        ˜          # Flatten this list as well
                  # Pair both lists together
                   #  i.e. [["Y","耀","耀","耀","Y","H","%","耀","耀","耀","耀","耀"],
                   #        ["耀","b","b","耀","耀","H","耀","耀","%","%","耀","%"]]
 ø                 # Swap its rows and columns to create pairs
                   #  i.e. [["Y","耀"],["耀","b"],["耀","b"],["耀","耀"],["Y","耀"],["H","H"],["%","耀"],["耀","耀"],["耀","%"],["耀","%"],["耀","耀"],["耀","%"]]
  ʒË}              # Filter out any inner lists where both characters are not equal
                   #  i.e. [["耀","耀"],["H","H"],["耀","耀"],["耀","耀"]]
     ʒXå≠}         # Filter out any inner lists that contain the character `X`
                   #  i.e. [["H","H"]]
g                  # Take the length as result
                   #  i.e. [["H","H"]] → 1
 q                 # Stop the program, making all other characters no-ops
                   # (and output the length above implicitly)


0

জাভাস্ক্রিপ্ট (নোড.জেএস) , 0 (279 বাইট)

  s=>(b=s.map(Buffer)).map((x,i)=>x.filter((y,j)=>y-(g=(x,y)=>~~(b[x]&&b[x][y]))(i,j-1)&&y-g(i,j+1)&&y-g(i-1,j)&&y-g(i+1,j))).join``.length
//s=>(b=s.map(Buffer)).map((x,i)=>x.filter((y,j)=>y-(g=(x,y)=>~~(b[x]&&b[x][y]))(i,j-1)&&y-g(i,j+1)&&y-g(i-1,j)&&y-g(i+1,j))).join``.length

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

লাইনের অ্যারে হিসাবে ইনপুট পান।

আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.