বাইনারি সময় কি?


14

বাইনারি সময় কি?

সকলেই জানেন যে সাধারণ সময়টি কী। এটি আপনার স্ক্রিনের উপরের-ডানদিকে (বা যেখানেই আপনি রাখুন) সেখানে রয়েছে। কিন্তু একটি প্রশ্ন লোকেরা খুব কমই নিজেকে জিজ্ঞাসা করে বলে মনে হয় এটি হ'ল: বাইনারি সময়টি কী?

বাইনারি সময়

বাইনারি টাইম (ট্রু বাইনারি টাইম) প্রথমে সংখ্যার উল্লেখযোগ্য বিট (এমএসবি) পড়ে কাজ করে। যদি সংখ্যাটি হয় 0তবে প্রকাশের সময়টি দুপুরের আগে। যদি সংখ্যাটি হয় 1তবে প্রকাশের সময়টি দুপুরের পরে। পরের বিটটি দিনের অর্ধেকটি বিভক্ত করে প্রথম বিটটি আরও দুটি সমান অর্ধেক হিসাবে প্রকাশিত হয়, এই সময়টি 6 ঘন্টা। নিম্নলিখিত বিটটি 3 ঘন্টা, পরবর্তী 90 মিনিট, এবং এর মধ্যে বিভক্ত হয়। টাইমস পছন্দ করে 12:00:00, যেখানে এটি মনে হয় এটি দুটোই হওয়া উচিত নয়, হয়ে ওঠে 1

আমি কেবল সময়ের এই অদ্ভুত সিস্টেমটি বুঝতে পারি, সুতরাং আমার কাছে এটি রূপান্তর করার জন্য আমার একটি প্রোগ্রাম প্রয়োজন। তবে বাইনারি সংখ্যাগুলি বেস -২ এবং 2 হ'ল একটি ছোট সংখ্যা, আপনার প্রোগ্রামটি যতটা সম্ভব সংক্ষিপ্ত হওয়া উচিত।

আবশ্যকতা

  • আপনার প্রোগ্রামটি ইনপুট হিসাবে সময় নিতে হবে (24 ঘন্টা সময় হিসাবে) এবং সংশ্লিষ্ট বাইনারি সময় নম্বর আউটপুট।
  • আউটপুট নম্বরটিতে 16-বিট নির্ভুলতা থাকা উচিত (সংখ্যাটি 16 সংখ্যার দীর্ঘ হওয়া উচিত)।
  • আপনি এমন কোনও বিল্টিন ব্যবহার করতে পারবেন না যা আপনার জন্য সেই সমস্ত রূপান্তর করে।
  • এটি বৃত্তাকার করা প্রয়োজন হলে আপনি মেঝে করা উচিত।

বিধি

পরীক্ষার কেস

00:00:00==> 0000000000000000
12:00:00==> 1000000000000000
01:30:00==> 0001000000000000
10:33:06==> 0111000010001101
09:57:30==> 0110101000111000
06:00:00==> 0100000000000000
18:00:00==>1100000000000000

স্কোরিং

জিততে, যেমন আমি আগেই বলেছি, আপনার অবশ্যই কমপক্ষে বাইট থাকতে হবে।

জমা

আপনার উত্তরটি প্রদর্শিত হয়েছে তা নিশ্চিত করার জন্য, দয়া করে নীচের মার্কডাউন টেমপ্লেটটি ব্যবহার করে আপনার উত্তরটি শিরোনাম দিয়ে শুরু করুন:

# Language Name, N bytes

Nআপনার জমা দেওয়ার আকারটি কোথায় ? আপনি যদি নিজের স্কোরটি উন্নত করেন তবে আপনি পুরানো স্কোরগুলি শিরোনামে রেখে দিতে পারেন । এই ক্ষেত্রে:

# Ruby, <s>104</s> <s>101</s> 96 bytes

যদি আপনি নিজের শিরোনামে একাধিক সংখ্যা অন্তর্ভুক্ত করতে চান (যেমন আপনার স্কোর দুটি ফাইলের সমষ্টি বা আপনি আলাদাভাবে দোভাষী পতাকা দণ্ডের তালিকা করতে চান), নিশ্চিত করুন যে আসল স্কোরটি শিরোনামের শেষ সংখ্যা:

# Perl, 43 + 2 (-p flag) = 45 bytes

আপনি ভাষাটির নামটিকে একটি লিঙ্কও বানাতে পারেন যা লিডারবোর্ড স্নিপেটে প্রদর্শিত হবে:

# [><>](http://esolangs.org/wiki/Fish), 121 bytes

লিডারবোর্ড

নিয়মিত লিডারবোর্ড এবং ভাষার দ্বারা বিজয়ীদের একটি সংক্ষিপ্ত বিবরণ উভয়ই তৈরি করতে এখানে একটি স্ট্যাক স্নিপেট।


3
আমি কি হিসাবে ইনপুট করতে পারি [hour, minute, second]? আমরা ইনপুট ফর্ম্যাটটিকে সীমাবদ্ধ রাখতে পছন্দ করি না।
ফাঁস নুন

2
কেমন করে 09:57:30করতে 0110110000000000?
ফাঁস নুন

2
16 বিট কেবল 65536 মান উপস্থাপন করতে পারে। একদিনে 86400 সেকেন্ড রয়েছে। বাইনারি উপস্থাপনের সাথে মেলে না এমন কোনও কিছু কীভাবে আমাদের উপস্থাপন করা উচিত?
পূর্কাকুডারী

আমরা কি 16 সংখ্যার একটি তালিকা হিসাবে ফলাফলটি ফিরিয়ে দিতে পারি?
অ্যাডম

@ অ্যাডাম হ্যাঁ, আপনি পারেন।
জর্জ গিবসন

উত্তর:


1

এমএটিএল , 15 বাইট

YOtk-KWW*k16&YB

সময়কে প্রতিনিধিত্ব করে একটি সিরিয়াল তারিখ / সময় সংখ্যায় রূপান্তর করার জন্য একটি বিল্টিন ব্যবহার করে, যা চ্যালেঞ্জের দ্বারা অনুমোদিত।

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

ব্যাখ্যা

YO       % Input time string. Convert to serial date/time. Time is fractional part
tk-      % Duplicate, round down, subtract. This keeps fractional part only
KWW      % 34, 2 raised to, 2 raised to (`16W` would require an extra space)
*        % Multiply
k        % Round down
16&YB    % Convert to binary string with 16 digits. Display

5

সিজোম, 20 বাইট

l':/60b9m<675/2bG0e[

পরীক্ষা স্যুট.

ব্যাখ্যা

65536 (2 16 ) 86400 (এক দিনের সেকেন্ডের সংখ্যা) 675 এর বেশি হয়ে 512 এ সরল করে তোলে এমনটি ব্যবহার করে।

l     e# Read input.
':/   e# Split around ':', so we get ["hh" "mm" "ss"].
60b   e# Interpret as base-60 digits, which computes hh*60^2 + mm*60 + ss,
      e# i.e. it computes the total number of seconds. Note that this implicitly
      e# converts all three strings to integers.
9m<   e# Bitwise left-shift by 9 positions, which is the same as multiplying by
      e# 2^9 = 512.
675/  e# Divide by 675, flooring the result.
2b    e# Convert to binary.
G0e[  e# Left-pad with zeros to 16 digits.

3

পাইথ, 31 27 বাইট

.[\016.Bs*512cisMcQ\:60 675

পরীক্ষা স্যুট.

ইনপুটটিকে পাস হওয়া সেকেন্ডের সংখ্যায় রূপান্তর করে, এর একটি ফ্যাক্টর দ্বারা গুণিত 2^16 / 24*60*60এবং তারপরে মেঝেতে এবং 16-বিট বাইনারি রূপান্তর করে।

সরল 65536/86400করে 4 বাইট সংরক্ষণ করেছেন 512/675(আমাকে বোকা)।

ইনপুট আউটপুট

00:00:00    0000000000000000
11:00:00    0111010101010101
12:00:00    1000000000000000
01:30:00    0001000000000000
10:33:06    0111000010001101
09:57:30    0110101000111000
06:00:00    0100000000000000
18:00:00    1100000000000000
23:59:59    1111111111111111

আপনি কি " এবং তারপরে " ন্যায্যতা বলতে পারেন ?
পিটার টেলর

@ পিটারটেলর @ এর পরিবর্তে আমার কী করা উচিত?
ফাঁস নুন

4
কোনও উত্তর পোস্ট করার আগে এই অনুমানটি ক্ষুন্ন না হওয়া পর্যন্ত অপেক্ষা করুন।
পিটার টেলর

@ পিটারটেলর রাউন্ডিংয়ের সঠিক উপায়টি স্পষ্ট 10:33:06
আদম

@ অ্যাডাম, সত্যই নয়, কারণ এটি তল এবং রাউন্ড-টু-নিকটতম সহ একই আউটপুট দেয়।
পিটার টেলর

3

টিএসকিউএল (স্কেলসার্ভার 2012), 103 বাইট

DECLARE @d datetime = '10:33:06'

DECLARE @ char(16)='',@x INT=cast(@d as real)*131072WHILE
len(@)<16SELECT @x/=2,@=concat(@x%2,@)PRINT @

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

Ungolfed

DECLARE @d datetime = '10:33:06'

DECLARE @ char(16)='',
        @x INT=cast(@d as real)*131072
WHILE len(@)<16
SELECT @x/=2,@=concat(@x%2,@)
PRINT @

টিএসকিউএল (স্ক্লোসারভার 2012), 119 106 বাইট

পরিবর্তনশীল @ x ব্যতীত একটি আলাদা সংস্করণ অন্তর্ভুক্ত করা হয়েছে, তবে এটি কয়েক বাইট দীর্ঘ ছিল। আগ্রহীদের জন্য অসম্পূর্ণ সংস্করণ সহ:

DECLARE @d datetime = '23:59:59'

DECLARE @ varchar(16) =''
WHILE LEN(@)<16
SET @+=LEFT(CAST(@d as decimal(9,9))*2*POWER(2,LEN(@))%2,1)
PRINT @

গল্ফ লাগছে না। আপনি কি অনেকটা সাদা জায়গা সরাতে পারবেন না?
অ্যাডম

@ অ্যাডম এটি খুব গল্ফড, আমি স্ক্রিপ্টকে আরও ছোট করার জন্য স্ট্যান্ডার্ডের চেয়ে আলাদা পদ্ধতি ব্যবহার করেছিলাম এমনকি একটি আলাদা পদ্ধতিও চেষ্টা করেছি। কোডগল্ফে আমার উত্তরটি কপি করার সময় আমার কেবলমাত্র একটি দুর্ঘটনাযুক্ত শ্বেতস্থান ছিল (কেবলমাত্র একটি অতিরিক্ত)। আমি সেখানে একটি লাইন ব্রেক লাগাতে চেয়েছিলাম, তবে পরিবর্তে WHIL এর পরে রাখার সিদ্ধান্ত নিয়েছি। স্থানটি
সরাতে

@ অ্যাডাম এবং আপনি যদি দ্বিতীয় পদ্ধতিটির দিকে তাকান তবে এটি গল্ফ হয় না (চরিত্রের গণনা ব্যতীত), কারণ এটি আমার আসল উত্তর নয়। এটি সমাধানের জন্য আরও একটি পৃথক গণনা পদ্ধতি
t-clausen.dk

3
না, আমি কমে যাইনি। সম্ভবত এমন কেউই ছিলেন যার বিপি এর আগে পোস্ট করা সমস্ত উত্তরকে নীচে রাখার নীতি রয়েছে এবং বকেয়া নিয়মের প্রশ্নগুলি স্পষ্ট করে দেয়। খুব নতুন উত্তর ব্যতীত অন্যগুলির হুবহু একটি ডাউনভোট রয়েছে। (এটি সম্ভবত পিটার টেইলর ছিলেন, কারণ তিনি এই পোস্টের ঠিক আগে এখানে এসেছিলেন, এবং তিনি এই সম্পর্কে অভিযোগও করেছেন।) আপনার যথেষ্ট প্রতিনিধি পেলে আপনি এটি দেখতে পাবেন। এখানে, কিছু আছে!
অ্যাডম

2

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

THX @ নীল সংরক্ষণ 4 বাইট সম্পাদনা করুন

রাউন্ডিং সম্পর্কে এখনও অস্পষ্ট। এই এক কাটা এবং এটি ঠিক আছে।

t=>(t.split`:`.map(v=>t=+v+60*~~t),t*512/675|65536).toString(2).slice(1)

পরীক্ষা

f=t=>(t.split`:`.map(v=>t=+v+60*~~t),t*512/675|65536).toString(2).slice(1)

function test() {
  var v=I.value
  R.textContent=f(v)
}

test()


;`00:00:00 ==> 0000000000000000
12:00:00 ==> 1000000000000000
01:30:00 ==> 0001000000000000
10:33:06 ==> 0111000010001101
09:57:30 ==> 0110101000111000
06:00:00 ==> 0100000000000000
18:00:00 ==> 1100000000000000`
.split('\n').forEach(t=>{
  [i,k]=t.split(' ==> ')
  r=f(i)
  ok=r==k
  O.textContent += (ok ? 'OK ':'KO ')+ i + ' -> ' + r + (ok? '\n' : ' Expected '+k+'\n')
})
<input id=I value='12:34:56' oninput=test()>
<span id=R></span>
<pre id=O></pre>


কেন এটিকে
নিম্নচেতন করা

t=>([h,m,s]=t.split`:`,(+h+m/60+s/3600)*8192/3|65536).toString(2).slice(1)আপনাকে 2 বাইট সংরক্ষণ করে, তবে reduceআরও একটি বাইটে যায়:t=>(t.split`:`.reduce((n,m)=>+m+n*60)*512/675|65536).toString(2).slice(1)
নিল

কোনও মন্তব্য ছাড়াই
ডাউনভোটটি

@ নীল আপনাকে অনেক ধন্যবাদ! এবং .map 1 আরও বাইট সংরক্ষণ করা হয়েছে
edc65

হু, আমি ভাবছিলাম যে আপনি কোথায় মানচিত্রের জন্য 0 পাবেন ...
নীল

1

এপিএল (ডায়ালগ) , 24 21 বাইট

বিধি এখন স্পষ্ট করা হয়েছে।

3-উপাদান তালিকা হিসাবে সময়ের জন্য অনুরোধ জানানো হয়।

(16/2)⊤⌊512×675÷⍨60⊥⎕

সম্পাদনা করুন: 10:33:06 এর জন্য নতুন ফলাফলের সাথে মেলে আপডেট ( )।

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

 ইনপুট জন্য প্রম্পট

60⊥ বেস -60 এ মূল্যায়ন করুন

675÷⍨ 675 দ্বারা ভাগ করুন

512× 512 দ্বারা গুন করুন

 মেঝে

(...)⊤  রূপান্তর করুন (স্মৃতিচারণ: আপসাইড-ডাউন বেসটি অ্যান্টি-বেস) নীচের নম্বর সিস্টেম:

16/2 2 ষোল বার প্রতিলিপি করুন (অর্থাত্ 16 বিট বাইনারি)   


0

প্রশ্ন, 32 বাইট

48_0b\:_(512%675)*60/:"I"$":"\:

পরীক্ষা

   t "00:00:00"
0000000000000000b
   t "12:00:00"
1000000000000000b
   t "01:30:00"
0001000000000000b
   t "10:33:06"
0111000010001101b
   t "09:57:30"
0110101000111000b
   t "06:00:00"
0100000000000000b
   t "18:00:00"
1100000000000000b
  • ডিসপ্লে ক্লাটারিং হ্রাস করার জন্য, আমি মূল এক্সপ্রেশনটিতে সামান্য পরিবর্তন অনুমান করি tযা ল্যাম্বডাকে নাম দেয়

  • b প্রত্যয় বাইনারি নির্দেশ করে

ব্যাখ্যা

দ্রষ্টব্য- বাম থেকে ডানে পড়ুন, ডান থেকে বামে মূল্যায়ন করুন

হিসাবে পড়ুন: 512 লভ্যাংশের তল বাইনারি উপস্থাপনা থেকে 48 টি 675 দ্বারা বিভক্ত এবং 60: স্কেলারফ্র্যাম্পেক্টর দ্বারা গুণিত হয়েছে ":" মূল স্ট্রিংয়ের বিভাজন থেকে পূর্ণসংখ্যার উপরে cast

মূল্যায়ন:

":"\:x ":" অক্ষরে (স্ট্রিং এক্স (ল্যাম্বডের অন্তর্নিহিত আরগ) বিভক্ত করুন (চটি বোঝাতে Q "" "ব্যবহার করে)

"I"$x কাস্ট স্ট্রিং (গুলি) x থেকে ইন্ট (গুলি) -> ঘন্টা, মিনিট, সেকেন্ড

60/:x ইনট -> সেকেন্ডের মোটের ক্রম থেকে একক মান গণনা করতে বেস 60 ব্যবহার করে

(512%675)*x অনুপাত গণনা করে 512%675(% বিভাজক) এবং কয়েক গুণ সেকেন্ডে। 512% 675 হ'ল ভগ্নাংশের সরলীকৃত ফর্ম (মোট সেকেন্ডস পার্ডে% 64 কে)

_ x ফ্লোট এক্স এর তল নির্দেশ করে

0b\:x এক্স এর বাইনারি উপস্থাপনা গণনা করে (64 বিট)

48_ x প্রথম 48 বিট বাদ দিন, তাই আমাদের 16 বিট উপস্থাপনা আছে

উদাহরণ (x = "01:30:00")। নোট.- "/" লাইনের শেষের দিকে মন্তব্য নির্দেশ করে

":"\:"01:30:00" /-> ("01";"30";"00") "I"$ /-> 1 30 0 60/: /-> 5400 (512%675)* /-> 4096.0 _ /-> 4096 0b\: /-> 0000000000000000000000000000000000000000000000000001000000000000b 48_ /-> 0001000000000000b


0

রুবি, 75 বাইট

h,m,s=t.split(':').map &:to_i;((h*3600+m*60+s<<9)/675).to_s(2).rjust 16,'0'

আমার মনে হয় সময়কে সেকেন্ডে রূপান্তর করার জন্য একটি ছোট্ট পদ্ধতি থাকতে হবে তবে আমি এটি ভাবতে পারি।


0

পাইথন, 45 বাইট

lambda h,m,s:bin((s+m*60+h*3600)*512/675)[2:]

512/675আমি নিজেই ফ্যাক্টরটি নিয়ে এসেছি , তারপরে অন্যরাও এটি করেছে saw


0

সি, 91 বাইট

f(h,m,s,n,i){i=0;n=(s+m*60+h*3600)*512/675;while(i<16)printf((n&32768)?"1":"0"),n<<=1,i++;}

0

পিএইচপি, 47 46 43 বাইট

আইবিএম -850 এনকোডিং ব্যবহার করে।

printf(~┌Ø,strtotime($argn.UTC,0)*512/675);

এভাবে চালান:

echo "18:00:00" | php -nR 'printf(~┌Ø,strtotime($argn.UTC,0)*512/675);';echo

বদলান

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