색인 가능한 퀴네


14

이 과제의 목표는 소스 코드의 n 번째 문자를 출력하는 프로그램을 만드는 것입니다. 여기서 n은 프로그램에 입력으로 제공됩니다. 대부분의 quine 과제와 마찬가지로 소스 코드를 파일로 읽거나 내장 quine 함수를 사용할 수 없습니다.

입력

정수 0 <= n <len (프로그램).

산출

프로그램의 n 번째 문자 (바이트 아님)

승리

대부분의 codegolf 질문과 마찬가지로 가장 적은 수의 바이트를 사용하여 문제를 해결함으로써 문제를 해결할 수 있습니다.

보너스

-5 % 프로그램이 음의 인덱스 파이썬 스타일을 지원하는 경우 (예 : -1이 프로그램의 마지막 문자 임). 아래 보너스와 함께 사용하는 경우 범위는 음의 지수를 지원해야합니다.
-20 % 프로그램이 위 요구 사항 외에 입력 (모든 형식)으로 범위를 지원하는 경우.
프로그램이 두 보너스를 모두 완료하면 -25 %

리더 보드

다음은 일반 리더 보드와 언어 별 수상자 개요를 생성하는 스택 스 니펫입니다.

답변이 표시되도록하려면 다음 마크 다운 템플릿을 사용하여 헤드 라인으로 답변을 시작하십시오.

# 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


quine 내장은 금지되어 있습니까?
Mego

@ Mego 네, 그렇습니다.
TheNumberOne

보너스가 쌓이거나 (100 %-20 %-5 % = 75 %) 곱하기 (100 % * 80 % * 95 % = 76 %)입니까?
ETHproductions

실제로 입력을 읽지 않는 프로그램이 있습니까?
Neil

@ETHproductions 스택.
TheNumberOne

답변:


12

피 이스, 0.75

(CJam 폴리 글롯이자 많은 다른 언어 일 수도 있습니다.)

0

STDIN에 대한 입력이 예상됩니다.

llama@llama:~$ echo 0..0 | pyth -c '0'
0

물론 모든 한 자리 숫자가 작동합니다. Pyth에서 가장 흥미로운 도전은 아닙니다.


1
다른 많은 언어에서도 폴리 글 로트가됩니다.
Mama Fun Roll

PlatyPar에서도 작동
Cyoce

1
및 JAPT 및 Jolf, 암시 적 출력 거의 모든 언어
ETHproductions

9
그리고 골프를위한 최고의 언어 인 PHP도 있습니다.
user253751 2019

8

자바 스크립트 ES6, 31 바이트

$=_=>`$=${$};$()`[prompt()];$()

설명

표준 퀴네 프레임 워크 :

$=_=>`$=${$};$()`;$()

[prompt()]애드온 인은 결과 퀴네 문자열의 입력 인덱스에서 값을 가져옵니다.


6

𝔼𝕊𝕄𝕚𝕟, 9 문자 / 19 바이트

⟮ɕṡ+ᶈ0)⎖ï

Try it here (Firefox only).

Ay, 19 번째 바이트!

0 작동하지만 훨씬 좋습니다.하지만 좋아하는 것은 너무 사소합니다.

또한, ℹ ï,⧺ï도 작동하지만 quine 기능은 허용되지 않습니다 것입니다.

설명

표준 quine 프레임 워크는 ⟮ɕṡ+ᶈ0입니다.

)⎖ï 결과 quine 문자열을 가져 와서 입력 색인에서 문자를 가져옵니다.


보너스 솔루션, 11.4 자 / 25.65 바이트

⟮ᵖ…ɕṡ+ᶈ0;ôᵍï

Try it here (Firefox only).

이것은 5 % 보너스를받을 자격이 있지만 원래 제출물을 초과하지는 않습니다.

설명

이것은 스택을 사용합니다. ᵖ…ɕṡ+ᶈ0;quine 문자열의 개별 문자를 스택으로 푸시하고 스택 ôᵍï의 입력 색인 (양수 또는 음수)에서 문자를 직접 출력합니다.


아직 인코딩을하지 않은 이유는 무엇입니까?
애디슨 크럼

업데이트가 너무 빨리옵니다! 유지할 수 없습니다!
Mama Fun Roll

5

CJam, 12.35 바이트

{s"_~"+ri=}_~

프로그램의 길이 는 13 바이트 이며 × 0.95 보너스를받을 수 있습니다.온라인으로 사용해보십시오!

작동 원리

{         }      Define a code block.
           _~    Push a copy and execute the copy.
 s               Cast the original code block to string.
  "_~"+          Append "_~".
       ri        Read an integer from STDIN.
         =       Retrieve the character at that index.

4
물론 0조금 더 짧았을 것입니다 ...
Dennis

4

루비, 53 * 0.75 = 39.75

$><<(<<2*2+?2)[eval gets]
$><<(<<2*2+?2)[eval gets]
2

2자체 행에서 HEREDOC 문자열을 구분하여 생성하고이를 연결 ( *2) 한 다음 2문자 리터럴을 통해 마지막에 추가합니다 . String#[]양의 정수, 음의 정수 및 범위 (형식으로 입력)를 지원 하는 Ruby의 내장을 사용하여 슬라이스 합니다 m..n. $><<출력됩니다. ( puts여기에는 추가 공간이 필요합니다).


나는와 gets.to_i같은 일을 eval gets하고 더 명확 하다고 생각 합니다. 이 정수가 아닌 입력을 처리 할 것입니다,하지만 필요하지 어쨌든입니다
기금 모니카의 소송

그것은 일반적으로 내가하는 일이지만, 이것은 Ranges 처리에 대한 보너스를 얻습니다. (또한 튜링 완료에 대한 존재하지 않는 보너스).
histocrat

아, 나는 그것을 놓쳤다. 내 잘못이야.
기금 모니카의 소송

3

루비, 38.25 바이트

a="a=%p;$><<(a%%a)[eval gets]";$><<(a%a)[eval gets]

음수 인덱스 및 범위를 지원합니다. 나는 노골적으로 집어 모두 $><<evalhistocrat에서 트릭, 그리고이 CW를 만들거야 그래서 quine 트릭로 시작하는 다른 사람이었다.


1

파이썬 2, 46.55 바이트

a="a=%r;print(a%%a)[input()]";print(a%a)[input()]

음수 지수를 지원합니다.


네, 이것은 부정적인 지수를 지원합니다.
고양이

1

하스켈, 122 바이트

main=getLine>>= \i->putChar$(!!(read i))$p++show p where p="main=getLine>>= \\i->putChar$(!!(read i))$p++show p where p="

언 골프 드 :

main=getLine>>= \i->putChar$(!!(read i))$p++show p
 where p="main=getLine>>= \\i->putChar$(!!(read i))$p++show p\n where p="

1

Befunge 93, 5 바이트

이것은 꽤 (매우) 늦었지만 어쨌든 게시 할 것입니다.

&0g,@

1
이것은 법적 IMO의 가장자리에 있습니다. 자체 소스 코드 를 file로 읽지 않지만 자체 소스 코드를 읽습니다.
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.