ค้นหาทุกครั้งที่เป็นไปตามรูปแบบ


13

งานของคุณคือเขียนโปรแกรมที่พิมพ์ตลอดเวลา (ในรูปแบบ HH: MM, 24 ชั่วโมง) ที่เป็นไปตามรูปแบบใดรูปแบบหนึ่งดังต่อไปนี้:

  • จำนวนชั่วโมงเท่ากับนาทีเช่น 22: 22,01: 01
  • ชั่วโมงเท่ากับนาทีย้อนกลับเช่น 10:01, 01:10, 22:22
  • ลำดับที่ตรงกับ H: MM หรือ HH: MM พิมพ์ด้วย HH: MM เสมอ เช่น 00:12, 01:23, 23:45, 03:45, ฯลฯ (เป็นขั้นตอนเดียวเสมอระหว่างตัวเลข)

กฎ:

  • คุณสามารถเลือกภาษาที่คุณชอบ
  • คุณไม่สามารถพิมพ์เวลาซ้ำได้
  • หนึ่งครั้งต่อบรรทัดตามคำสั่งของวัน
  • ผู้ชนะจะได้รับการคัดเลือกใน 5 กุมภาพันธ์

PS: นี่เป็นคำถามแรกของฉันมันอาจมีความไม่สอดคล้องกันบ้าง รู้สึกอิสระที่จะแก้ไข

PS2: นี่คือโซลูชันที่คาดหวัง 44 รายการ (นำเสนอโดย Josh และ primo แล้วขอบคุณ!)

00:00
00:12
01:01
01:10
01:23
02:02
02:20
02:34
03:03
03:30
03:45
04:04
04:40
04:56
05:05
05:50
06:06
07:07
08:08
09:09
10:01
10:10
11:11
00:12
00:21
00:34
13:13
13:31
14:14
14:41
15:15
15:51
16:16
17:17
18:18
19:19
20:02
20:20
21:12
21:21
22:22
23:23
23:32
23:45

2
ฉันคาดหวังว่า3:45จะถูกเขียน03:45ในHH:MMรูปแบบและไม่ใช่ลำดับ
Howard

ขวา! ฉันคิดถึงสิ่งนั้นในตัวอย่าง
RSFalcon7

3
จะ13:57นับเป็นลำดับหรือไม่ เกี่ยวกับ6:54อะไร ในโน้ตตัวเดียวกันก็6:42ต้องตัดสินใจเช่นกัน
John Dvorak

3
เวลาที่มีเพียงตัวเลขเดียวที่ไม่ใช่ศูนย์นำเช่น00:01นับเป็นลำดับหรือไม่
Josh

2
@ RSFalcon7 ดังนั้นเลขศูนย์นำหน้าจะถูกละเว้น? อันไหน? 23:45, 02:34, 00:23, 00:02 ดูเหมือนว่าจะเป็นกรณีที่คล้ายกัน
Joachim Isaksson

คำตอบ:


4

Golfscript ( 82 72)

ยังเป็นผู้เริ่มต้นมาก แต่ไม่มีคำตอบของ GS ดังนั้น ... :)

24,{'0'\+-2>..+\.-1%+}%5,{'0'7,{+}/>4<.(;0\+}%|{2=54<},$);{2/~':'\++}%n*

PHP จะไม่สามารถเอาชนะได้
primo

และ C แน่นอนจะไม่สามารถเอาชนะได้
Josh

4

PHP - 93 ไบต์

<?for(;24>$h;)@ereg(+$h=&date(i,$i).$m=date(s,$i++),"0123456$h$h".strrev($h))&&print"$h:$m
";

นี้จะหารูปแบบเช่น02:34แต่จะไม่หารูปแบบที่เหมือนหรือ00:23 00:02หากฉันเข้าใจคำอธิบายของ OP ในความคิดเห็นแสดงว่าสิ่งนี้ถูกต้อง

พิมพ์ผลลัพธ์ทั้งหมด 44 รายการ:

00:00
00:12
01:01
01:10
01:23
02:02
02:20
02:34
03:03
03:30
03:45
04:04
04:40
04:56
05:05
05:50
06:06
07:07
08:08
09:09
10:01
10:10
11:11
12:12
12:21
12:34
13:13
13:31
14:14
14:41
15:15
15:51
16:16
17:17
18:18
19:19
20:02
20:20
21:12
21:21
22:22
23:23
23:32
23:45

4

C, 118 (เริ่มต้น 136)

h,m;main(){h<24&&main(m>57?m=0,h++:h==m|h==m%10*10+m/10|m-12==h*11|h==m-22&!(~-m++%11)&&printf("%02d:%02d\n",h,m-1));}

เวอร์ชันซ้ำที่มีอักขระ 119 ตัว:

h;main(m){for(;h<24;h++)for(m=0;m<57;m++)h==m|h==m%10*10+m/10|m-12==h*11|h==m-22&!(~-m%11)&&printf("%02d:%02d\n",h,m);}

ขอขอบคุณ @squeamish ossifrage!


1
ควรจะดีตอนนี้
Josh

2
โซลูชันของฉันให้ผลลัพธ์เหล่านั้น (เช่น02:34) กฎm-12==h*11จับพวกเขา
Josh

2
คุณสามารถแทนที่100*h+m==1234||100*h+m==2345ด้วย((m-h)==22)&&!((m-1)%11)(อาจจะมีวงเล็บน้อยกว่า)
r3mainer

1
แจ๊คพ็อ! กลับลงไปที่ 128 ตัวอักษร ขอบคุณ!
Josh

1
00:01ความเข้าใจของฉันก็จะไม่รวมถึงลำดับที่มีเพียงหลักเดียวเช่น ฉันจะโพสต์คำถามเดิมเพื่อความกระจ่าง
Josh

2

Python (178)

s=sorted
for i in[x for x in['%04d'%i for i in range(2400)if i/10%10<6]if s(x[:2])==s(x[2:])or len({i-ord(y)for i,y in enumerate(x.lstrip('0'))})==1]:print'%2s:%2s'%(i[:2],i[2:])

การดึงศูนย์นำหน้าทั้งหมดก่อนที่ลำดับจะให้ผลลัพธ์ทั้งหมด 57 รายการ


2

APL (90)

F←{,'ZI2'⎕FMT⍵}⋄↑⊃¨{(F⍺),':',F⍵}/¨Z/⍨{(⍺=⍵)∨(≡/0 1⌽∘F¨⍺⍵)∨∧/¯1=2-/⍎¨(⍕⍺),F⍵}/¨Z←,1-⍨⍳24 60

แค่นั้นแหละ. ฉันจะทำให้ภาษาของ Perl ที่ทุกคำหลักและฟังก์ชั่นส่วนใหญ่เป็นตัวละครเดียว +1, btw;)
primo

1

Javascript - 171 chars (5/2/14)!

for(h='00';+h<24;h=(++h<10?'0':'')+h)for(m='00';+m<60;m=(++m<10?'0':'')+m)if(h[1]+h[0]==m||h==m||+m[1]-m[0]==1&&+m[0]-h[1]==1&&(!+h[0]||+h[1]-h[0]==1))console.log(h+':'+m)

ฉันจริงจังที่จะตีกอล์ฟ ถ้าฉันมองย้อนกลับไปจากนี้ฉันจะลดเหลือเกือบ 30 ตัวอักษร! JSBin

Ungolfed (และแสดงความคิดเห็น):

// Note: +'string' is same as 'parseInt(string, 10)'
// Also, this code is not the shortest one, I have purposely made this code longer for
// understanding purposes

for(h = '0'; +h < 24; h = +h + 1 + '') //initialize h(our), loop while it's less than 24
{                                      // increase it by 1 and cast back to string
    for(m = '0'; +m < 60; m= +m + 1 + '') // intialize m(inute), loop while < 60
    {                                  // increase it by 1 and cast back to string
        if(h.length < 2) h = 0 + h;    // if it is '9', convert to '09'
        if(m.length < 2) m = 0 + m;    // if it is '9', convert to '09'

        // Tests for printing
        if(h[0] === m[1] && m[0] === h[1] ||
           h === m ||
           +m[1] - +m[0] === 1 && +m[0] - +h[1] === 1 && (+h[0] === 0 || +h[1] -+ h[0] === 1))
        console.log(h + ':' + m);  // print
    } // inner loop end
}     // outer loop end

187 ตัวอักษร (เก่า) (4/2/14)

for(h='00';+h<24;h=(+h<9?'0':'')+(+h+1))for(m='00';+m<60;m=(+m<9?'0':'')+(+m+1))if(h[0]==m[1]&&m[0]==h[1]||h==m||+m[1]-m[0]==1&&+m[0]-h[1]==1&&(!+h[0]||+h[1]-h[0]==1))console.log(h+':'+m)

การทดลองเล็กน้อยและการปรับปรุงมาก (9 ตัวอักษร) :) JSBin

196 ตัวอักษร (เก่า) (3/2/14)

for(h='00';+h<24;h=(+h<9?'0':'')+(+h+1))for(m='00';+m<60;m=(+m<9?'0':'')+(+m+1))if(h[0]==m[1]&&m[0]==h[1]||h==m||+m[1]-m[0]==1&&+m[0]-h[1]==1&&(!+h[0]||+h[1]-h[0]==1))console.log(h+':'+m)

นั่งลงด้วยใจที่สดใหม่และปรับปรุงให้ดีขึ้นมันมากหนึ่งซับ :) JSBin

208 ตัวอักษร (เก่า) (2/2/14)

for(h='0';+h<24;h=+h+1+''){for(m='0';+m<60;m=+m+1+''){if(h.length<2)h=0+h
if(m.length<2)m=0+m
if(h[0]==m[1]&&m[0]==h[1]||h==m||+m[1]-+m[0]==1&&+m[0]-+h[1]==1&&(+h[0]==0||+h[1]-+h[0]==1))console.log(h+':'+m)}}

ให้เวลาที่ต้องการทั้งหมด 44 ครั้ง (แต่ละบรรทัดใหม่)

จะปรับปรุงรหัสของฉันต่อไป

ฉันขอขอบคุณข้อเสนอแนะใด ๆ ขอขอบคุณ.


อัพเดทล่าสุด !!
Gaurang Tandon

1

Python 3, 248 ตัวอักษร

คิดว่าฉันมาสายนิดหน่อยและไม่ค่อยดีเท่าไหร่ แต่ในที่สุดก็มี codegolf สิ่งแรกที่จะแบ่งปัน:

ฉันตัดสินใจที่จะสนับสนุนเฉพาะลำดับจริงเช่น 01:23 และ 23:45 ไม่ใช่ 00:12 อย่างไรก็ตามฉันเดิมพันมีมากมายที่ต้องทำดีกว่าดังนั้นโปรดไปข้างหน้าและแบ่งปันความคิดเห็นกับฉัน

import itertools as t
s=sorted
r=range
i=int
d='%02d'
e=d+':'+d
print([e%(i(a[0]),i(a[1])) for a in t.product([d% x for x in r(0,24)], [d% x for x in r(0,60)]) if s(a[0])==s(a[1]) or list(a[0]+a[1])==[str(x) for x in r(i(a[0][0]),i(a[1][-1])+1)]])

มีเวอร์ชั่นที่เป็นคำอธิบายพร้อมกับมันบนpastebinของฉัน


0

Delphi

ยังทำงานอยู่ แต่นี่คือสิ่งที่ฉันมีจนถึงตอนนี้
มันใช้งานได้ แต่ฉันแน่ใจว่าเป็นไปได้ที่จะทำให้มันสั้นลง
แก้ไข:พิมพ์ 48 ครั้ง

ไม่มีเยื้อง 422 ตัวอักษร

uses System.SysUtils,DateUtils;var t:TTime;a,b,c,d:integer;s:string;begin t:=StrToTime('00:01');while t<StrToTime('23:59')do begin s:=FormatDateTime('hhnn',t);a:=StrToInt(s[1]);b:=StrToInt(s[2]);c:=StrToInt(s[3]);d:=StrToInt(s[4]);if((a+1=b)and(b+1=c)and(c+1=d))or((a=0)and(b+1=c)and(c+1=d))or((a=0)and(b=0)and(c+1=d))or((a=d)and(b=c))or((a=c)and(b=d))then WriteLn(FormatDateTime('hh:nn',t));t:=IncMinute(t)end;ReadLn;end.

ด้วยการเยื้อง 557 ตัวอักษร

uses
  System.SysUtils, DateUtils;

var
  t:TTime;
  a,b,c,d:integer;
  s:string;
begin
  t:=StrToTime('00:01');
  while t<StrToTime('23:59')do
  begin
    s:=FormatDateTime('hhnn',t);
    a:=StrToInt(s[1]);
    b:=StrToInt(s[2]);
    c:=StrToInt(s[3]);
    d:=StrToInt(s[4]);
    if((a+1=b) and (b+1=c) and (c+1=d)) or
      ((a=0) and (b+1=c) and (c+1=d)) or
      ((a=0) and (b=0) and (c+1=d)) or
      ((a=d) and (b=c)) or ((a=c) and (b=d)) then
      WriteLn(FormatDateTime('hh:nn',t));
    t:=IncMinute(t)
  end;
  ReadLn;
end.

0

q (116)

distinct{t:string 00:00+x;$[(t[0 1]in(t[3 4];t[4 3]))|all 1=1_deltas{"I"$x}each t[0 1 3 4];t;"00:00"]}each til 1440

เพิ่ม 00:00 ถึง 23:59, ปลดเปลื้องสตริงแล้วตรวจสอบ (ทดสอบ 1 หรือ 2) หรือ 3

เอาท์พุท:

("00:00";"01:01";"01:10";"01:23";"02:02";"02:20";"03:03";"03:30";"04:04";"04:40";"05:05";"05:50";"06:06";"07:07";"08:08";"09:09";"10:01";"10:10";"11:11";"12:12";"12:21";"12:34";"13:13";"13:31";"14:14";"14:41";"15:15";"15:51";"16:16";"17:17";"18:18";"19:19";"20:02";"20:20";"21:12";"21:21";"22:22";"23:23";"23:32";"23:45")

0

PHP - 56 39 31 ไบต์

<? http_redirect("goo.gl/W2M5mo")?>

มันไม่ได้ทำให้งอกฎ แต่อย่างใด คุณต้องติดตั้งโมดูล pecl_http และตั้งค่า short_open_tag เป็น "1" ใน php.ini


+1 ถ้าไม่มีอะไรอื่นสำหรับหลบแม้ว่าคู่เต้นมันที่ 38 ตัวอักษรdisp(urlread('http://bit.ly/1fzhb3C')):)
โจอาคิม Isaksson

... แม้ว่าคุณอาจจะพิจารณากำหนดเองที่ออกแบบ HTML คงคุณโหลดเป็นส่วนหนึ่งของรหัสที่มามิฉะนั้นแฟ้มแบบคงที่จะทำ (และอย่างเท่าเทียมกันไม่ถูกนับ ... ?)
โจอาคิม Isaksson

-7

TI-BASIC

สำหรับเครื่องคิดเลข TI-84 ของคุณ

DelVar AWhile A<24:A+1→A:Disp A,":",A:End

3
คำถามนี้ตอบคำถามในทางใด?
Howard

2
เพื่อความเป็นธรรมคำถามที่รัฐ "ตาม รูปแบบใดรูปแบบหนึ่งต่อไปนี้"
Danny

2
@ แดนนี่ฉันคิดว่านี่เป็นการดัดกฎมากเกินไป
John Dvorak

1
@JanDvorak นี่เป็นวิธีการดัดกฎ ???
Timtech

2
ตกลง ... ขอคิดวิธีอื่นในการแสดงกฎนั้น ฉันยังไม่แน่ใจว่าคุณตีความผิดโดยตั้งใจหรือไม่ แต่ดูเหมือนชัดเจนพอสำหรับฉันเช่นเดียวกับนักสำรวจคนอื่น ๆ
John Dvorak
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.