Ankoun1 18 Точки

## Решение на първа задача от изпита на 22.12.2023

Може би това да е вариант за решаване на задачата

function decoderCriptoInformation(informationInput) {

let criptoInformation = informationInput.shift();

for (const information of informationInput) {

const [comand, firstElement, ...lastElement] = information.split('?');

let isValid = true;

if (comand === 'TakeEven') {

//criptoInformation = criptoInformation.replace(/(.)./g, '\$1');

criptoInformation = concatEvenElements(criptoInformation);

} else if (comand === 'ChangeAll') {

const searchRegExp = new RegExp(firstElement, 'g');

criptoInformation = criptoInformation.replace(searchRegExp, lastElement);

} else if (comand === 'Reverse') {

if (!criptoInformation.includes(firstElement)) {

isValid = false;

} else {

criptoInformation = criptoInformation.replace(firstElement, '');

criptoInformation = criptoInformation.concat(reverseElements(firstElement));

}

} else if (comand === 'Buy') {

console.log(`The cryptocurrency is: \${criptoInformation}`)

return;

} else {

isValid = false;

}

if (isValid) {

console.log(criptoInformation);

} else {

console.log('error')

}

}

function concatEvenElements(arr) {

let leftString = '';

let rigthString = '';

const elementLength = arr.length

for (let index = 0; index < parseInt(elementLength / 2); index++) {

let count = false

if (index % 2 == 0) {

leftString = leftString.concat(arr[index]);

if (parseInt(elementLength / 2) % 2 == 1) {

count = true;

}

if (index < parseInt(elementLength / 2) - 1) {

rigthString = rigthString.concat(arr[parseInt(elementLength / 2) + count + index]);

}

}

}

let stringEvenElements = leftString + rigthString;

if (elementLength % 2 == 1) {

stringEvenElements += arr[elementLength - 1];

}

return stringEvenElements;

}

function reverseElements(element) {

let leftString = '';

let rigthString = '';

const elementLength = element.length

for (let j = 0; j < parseInt(elementLength / 2); j++) {

leftString = leftString.concat(element[elementLength - 1 - j]);

rigthString = rigthString.concat(element[parseInt(elementLength / 2) - 1 - j]);

}

if (elementLength % 2 == 1) {

leftString += element[parseInt(elementLength / 2)];

}

return leftString + rigthString;

}

}

decoderCriptoInformation(["z2tdsfndoctsB6z7tjc8ojzdngzhtjsyVjek!snfzsafhscs",

"TakeEven",

"Reverse?!nzahc",

"ChangeAll?m?g",

"ChangeAll?z?i",

Тагове:
0
09/01/2024 21:16:38
cara123 1 Точки

Acquire a useful new knowledge. Thanks to the site for providing very good geometry dash documentation and information.

0
Можем ли да използваме бисквитки?
Ние използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Можете да се съгласите с всички или част от тях.
Назад
Функционални
Използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Използваме „сесийни“ бисквитки, за да Ви идентифицираме временно. Те се пазят само по време на активната употреба на услугите ни. След излизане от приложението, затваряне на браузъра или мобилното устройство, данните се трият. Използваме бисквитки, за да предоставим опцията „Запомни Ме“, която Ви позволява да използвате нашите услуги без да предоставяте потребителско име и парола. Допълнително е възможно да използваме бисквитки за да съхраняваме различни малки настройки, като избор на езика, позиции на менюта и персонализирано съдържание. Използваме бисквитки и за измерване на маркетинговите ни усилия.
Рекламни
Използваме бисквитки, за да измерваме маркетинг ефективността ни, броене на посещения, както и за проследяването дали дадено електронно писмо е било отворено.