Loading...
Dimitaradev avatar Dimitaradev 3 Точки

Премахване на съседни числа

3 зад. Да се напише програма, която изчита списък от цели числа. Ако в списъка има число, равно на своите съседи, то да се премахне. Тази процедура се повтаря, докато има такива числа. Да се изведе останалото от списъка или Empty, ако е празен.

Започнах задачата, но работа само когато входа ми е над 5 числа и гърми, ако останат по-малко от 3 числа. Някакви идеи?      https://dotnetfiddle.net/A3HSdm

 

Тагове:
0
Programming Basics
nickwork avatar nickwork 657 Точки

Пробвай това...добре е да даваш линк към джъдж за да тестваме решението...това което съм написал не е тествано..

Когато итерираш през някоя колекция и в същият момент премахваш елемент от нея това рефлектира и върху индексите....виж там сложил съм едно i-- което да компенсира премахването на елемнта... ако не работи решението пусни някакъв линк за тест

 List<int> nums = Console.ReadLine().Split().Select(int.Parse).ToList();
         
            if(nums.Count() > 2)
            {
                 for (int i = 1; i < nums.Count - 1; i++)
                 {
                    if(nums.Count() == 2) break;
                     
                    if (nums[i - 1] == nums[i] && nums[i + 1] == nums[i])
                    {
                          nums.Remove(nums[i]);
                          i--;
                    }
                 }
            }
            if(nums.Count == 0)
            {
                Console.WriteLine("Empty");
                break;
            }
            Console.WriteLine(string.Join(" ", nums));
        }

1
krum_43 avatar krum_43 756 Точки

Здравей колега,

При така зададеното условие задачата няма смисъл при въведени по-малко от 3 числа.

Списъкът от числа няма как да се изпразни тъй като ако останат 3 равни числа трием второто, а останалите 2 остават.

Ако не въведем нито едно число програмата дава:

Unhandled Exception: System.FormatException: Input string was not in a correct format.

При вход на по-малко от 3 числа( едно или две) просто ги извеждаме.

Ето ти един код,който работи добре,но не е тестван през системата.

 

using System;
using System.Collections.Generic;
using System.Linq;

namespace RemoveAdjacentNumbers
{
    class Program
    {
        static void Main(string[] args)
        {
            List<int> nums = Console.ReadLine().Split().Select(int.Parse).ToList();
            if (nums.Count() > 2)
            {
                for (int i = 1; i < nums.Count - 1; i++)
                {
                    if (nums.Count() == 2)
                    {
                        break;
                    }
                    if (nums[i - 1] == nums[i] && nums[i + 1] == nums[i])
                    {
                        nums.Remove(nums[i]);
                        i--;
                    }
                }
            }           
            Console.WriteLine(string.Join(" ", nums));
        }    
    }
 }

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