Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
 Аватар для Iangyl
32 / 34 / 21
Регистрация: 31.03.2018
Сообщений: 495

StackOverflowException

02.06.2019, 17:59. Показов 1265. Ответов 2

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Помогите решить проблему в коде.
Согласно Debug`еру встречается при вызове метода SortQueue.
Вот код:
Кликните здесь для просмотра всего текста
Main:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
static void Main(string[] args)
        {
            Random random = new Random();
            var numbers = new PriorityQueue();
            for (int i = 0; i < 10; i++)
            {
                int temp = random.Next(0, 100);
                numbers.Enqueue(temp);
            }
            numbers.ShowQueue();
            numbers.Dequeue();
            numbers.ShowQueue();
        }
Класс(очередь):
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
class PriorityQueue
    {
        private List<int> items = new List<int>();
        private int Head => items.Last();
        private int Tail => items.First();
        public int Count() => items.Count;
        public void Enqueue(int data)
        {
            items.Insert(0, data);
            items = SortQueue(items);
        }
        public int Dequeue()
        {
            var item = Head;
            items.Remove(item);
            return item;
        }
        public int Peek() { return Head; }
        public void ShowQueue()
        {
            for (int i = 0; i < items.Count; i++)
            {
                Console.WriteLine(items[0] + " - " + items[0] % 10);
            }
        }
        private List<int> SortQueue(List<int> list)
        {
            for (int i = 0; i < list.Count - 1; i++)
            {
                if ((list[i] % 10) > (list[i + 1] % 10))
                {
                    int temp = list[i + 1];
                    list[i + 1] = list[0];
                    list[0] = temp;
                }
            }
            bool check = true;
            for (int i = 0; i < list.Count - 1; i++)
            {
                if ((list[i] % 10) > (list[i + 1] % 10))
                {
                    check = false;
                    break;
                }
            }
            if (check == false) return SortQueue(list);
            else return list;
        }
    }
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
02.06.2019, 17:59
Ответы с готовыми решениями:

StackoverflowException
Есть класс в котором куча стринговых переменных с значениями и 5 простых. Пробовал уменьшать кол-во переменных до 24, но ошибка вылезает...

StackOverFlowException
Есть простенькое приложение, настолько простое что не могу понять откуда там ошибкам взяться, тем не менее StackOverFlowException в...

System.StackOverflowException
public string name { get { return name; } set { if (value != null)name = value; } } Результат...

2
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
02.06.2019, 20:08
Лучший ответ Сообщение было отмечено Iangyl как решение

Решение

Цитата Сообщение от Iangyl Посмотреть сообщение
C#
1
2
3
int temp = list[i + 1];
list[i + 1] = list[0];
list[0] = temp;
Местами-то, наверное, надо с i-м элементом менять, а не с первым?
Да и зачем вообще ручная сортировка? Полно же методов во фреймворке с готовой сортировкой — тот же Sort класса List, который вы используете.
1
 Аватар для Iangyl
32 / 34 / 21
Регистрация: 31.03.2018
Сообщений: 495
02.06.2019, 20:46  [ТС]
kolorotur, из-за условия сортировки. Я правда сначало тоже думал о методе List.Sort(), но как мне показалось он не принимает условий, по каким нужно сортировать.
Цитата Сообщение от Iangyl Посмотреть сообщение
C#
1
2
3
4
5
6
if ((list[i] % 10) > (list[i + 1] % 10))
{
    int temp = list[i + 1];
    list[i + 1] = list[0];
    list[0] = temp;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.06.2019, 20:46
Помогаю со студенческими работами здесь

StackOverflowException в Interface
Здравствуйте! Есть два интерфейса в разных .cs namespace Deposit { interface IPerson { int...

StackOverflowException в свойствах
Здравствуйте! Возник вопрос:не очень понимаю в честь чего в моем свойстве Price при установлении значения выпадает StackOverflow. Текст...

System.StackOverflowException
Создал рекурсивную функцию. Рекурсию нужно использовать в четырех местах, в общем, код ниже. Программа работает адекватно, если оставляю...

System.StackOverflowException
class Program { class Man { public int age { get; set; } public...

Ошибка StackOverflowException
Добрый вечер. Имею статичный класс Setting, в нём статичное свойство NowColor и конструктор класса. static class Settings{ ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru