일반적으로 도전 과제는 바이트 또는 때로는 레 벤슈 테인 거리로 점수가 매겨 지지만,이 거리에서는 프로그램을 입력하는 데 사용되는 키 사이의 키 수 인 키보드 거리를 사용합니다 (위의 키보드를 최종 참조로 사용하십시오). 예를 들어 경로가 => => => 이기 때문에 A와 사이의 거리는 F3 입니다. 경로 와 거리는 4입니다. 경로에 관계없이 4 단계 이상이 필요합니다. 당신의 임무는 가능한 작은 키보드 거리로 다음을 출력하는 것입니다 (후행 공백은 포함하지 않음).ASDFN5
Q W E R T Y U I O P
A S D F G H J K L
Z X C V B N M
외장:
생활을보다 쉽게하기 위해 특정 키가 키보드를 감쌀 수 있습니다. Left Shift줄 바꿈 Right Shift, Caps Lock줄 바꿈 Enter, Tab줄 바꿈 \및 ~줄 바꿈 Backspace. 예를 들어 => => => => => 이기 때문에 Q와 사이의 거리는 P5 입니다.QTab\][P
참고 : 줄 바꿈은 가로로만 작동 \합니다.Caps Lock
채점 :
점수 = 키보드 거리 + 바이트 수
계산 예 :
print(5);
- p=> r== 6
- r=> i== 4
- i=> n== 2
- n=> t== 3
- t=> (== 4
- (=> 5== 4
- 5=> )== 5
- )=> ;== 2
합계 : 30 + 9 = 39 .
노트:
- 소문자와 대문자는 동일한 키로 계산됩니다. 키에 두 개의 기호 (예 : 7및 &)가있는 경우 동일한 키로 계산되므로 Shift 키를 누를 필요가 없습니다.
- 불행히도 코드에 키보드에없는 기호가 필요한 경우 사용할 수 없습니다.
- 키보드 이미지에서 맨 위 행은 무시할 수 있습니다. 맨 아래 줄에서 사용할 수있는 유일한 키는Space
- 키는 순서대로 입력해야합니다. 화살표 키를 사용하여 캐럿을 이동 한 다음 키를 입력 할 수 없습니다.
점수 계산기 :
- `=> ]및 관련 오해를 수정하기 위해 12/27에 업데이트되었습니다 . 다시 점수를 확인하면 더 작아 질 수 있습니다.
점수를 계산하려면 여기에 코드를 붙여 넣으십시오. 오류가 발생하거나 잘못된 번호가 인쇄되면 알려주십시오.
var keys = ["~1234567890-=←","\tqwertyuiop[]\\","↑asdfghjkl;\'\n","Lzxcvbnm,./R",
"AB CDEF"];
var con =["`!@#$%^&*()_+{}|:\"<>?","~1234567890-=[]\\;\',./"];
function hexagon(k) {
if(k === " ") return ["x","c","v","b","n","m",","];
var p = pos(k);
if(p === -1) return false;
var row = p[0],col = p[1];
var hexagon = [char(row,col-1,1),char(row-1,col),char(row-1,col+1),char(row,col+1,1),char(row+1,col),char(row+1,col-1)];
return hexagon;
}
function char(r,c,wrap) {
if(r < 0 || r >= keys.length) return "";
if(r === keys.length-1 && 1 < c && c < 8) return " ";
if(wrap) {
if(c === -1) c = keys[r].length-1;
if(c === keys[r].length) c = 0;
}
return keys[r].charAt(c);
}
function pos(c) {
var row = -1, col = -1;
for(var i = 0;i<keys.length;i++) {
col = keys[i].indexOf(c)
if( col != -1) { row = i; break;}
}
if(row === -1) return -1;
return [row,col];
}
function dist(a,b,s,w) {
if(typeof a === "object") {
var list = [];
for(var i = 0;i<a.length;i++) {
list[i] = dist(a[i],b,s,w);
}
return list;
}
if(a==="") return Infinity;
if(a===b) return 0;
var p = pos(a);
var q = pos(b);
if(!w && a!==" ") {
var chars = keys[p[0]].length;
var opp = char(p[0],p[1] < chars/2 ? chars-1 : 0);
return Math.min(dist(a,b,s,true),dist(a,opp,s,true)+dist(opp,b,s,true));
}
if(!s) { return Math.min(dist(a,b,true,w),dist(a," ",true,w)+dist(" ",b,true,w));}
var h = hexagon(a);
if(a === " ") return 1 + Math.min(...dist(h,b,true,w));
if(p[0]<q[0]) {
return 1 + Math.min(dist(h[4],b,s,w),dist(h[5],b,s,w));
}
else if(p[0] > q[0]) {
return 1 + Math.min(dist(h[1],b,s,w),dist(h[2],b,s,w));
}
if(b===" ") return Math.min(Math.abs(p[1]-7),Math.abs(2 - p[1]));
var d = Math.abs(p[1]-q[1]);
return Math.min(d,keys[p[0]].length-d);
}
function getTotalDistance(str) {
for(var i = 0;i<con[0].length;i++)
str = str.replace(new RegExp("\\"+con[0].charAt(i),"g"),con[1].charAt(i));
str = str.toLowerCase();
var total = 0;
for(var i = 0;i<str.length-1;i++) {
total += dist(str[i],str[i+1]);
}
return total;
}
enter.onclick = function() {
var a = getTotalDistance(program.value);
var b = program.value.length;
len.textContent = a;
count.textContent = b;
total.textContent = a+b;
};
<textarea rows=15 cols=40 id="program"></textarea>
<input type="submit" id="enter"/>
<div>
<div>Key distance: <span id="len"></span></div>
<div>Byte count: <span id="count"></span></div>
<div>Total: <span id="total"></span></div>
</div>
관련 :
===
어떤 식 으로든 강제로 유형을 강요하고 성능을 저하 시키지 않기를 원하지 않는 한 신의 사랑에 감사 하십시오.