Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/29: Рейтинг темы: голосов - 29, средняя оценка - 4.72
0 / 0 / 0
Регистрация: 21.06.2011
Сообщений: 3

Метод сортировки пузырьком, исправить код

18.11.2012, 02:45. Показов 6146. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Метод сортировки пузырьком.

Когда ввожу числа, то ссылается на эту строку int n = int.Parse(Console.ReadLine());

Не могу разобраться в чем дело.

Код на C#:
Код:

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
class Program
    {
        static void Main(string[] args)
        {
  while (true)
            {
                Console.Write("введите размерность массива: ");
                int n = int.Parse(Console.ReadLine());
                if (n > 10)
                    Console.WriteLine("размерность массива не должна превышать 10 элементов\nповторите ввод!");
                else
                {
                    int[] mas = new int[n];
                    Console.WriteLine("заполните массив:");
                    for (int i = 0; i < n; ++i)
                    {
                        mas[i] = Convert.ToInt32(Console.ReadLine());
                    }
                    for (int j = 0; j < n - 1; ++j)
                    {
                        for (int i = 0; i < n - j - 1; ++i)
                        {
                            if (mas[i] <= mas[i + 1])
                            {
                                int m = mas[i];
                                mas[i] = mas[i + 1];
                                mas[i + 1] = m;
                            }
                        }
                    }
                    Console.WriteLine("полученный массив:");
                    for (int i = 0; i < n; ++i)
                    {
                        Console.Write(mas[i] + " \t");
                    }
                    Console.WriteLine();
                    Console.WriteLine("повторить?да-0,нет-1");
                    int otvet = int.Parse(Console.ReadLine());
                    if (otvet != 0)
                        break;
                }
            }
        }
    }
}
И ещё, нужно сделать не сложную лабу на С#, кто заинтересован - пишите.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.11.2012, 02:45
Ответы с готовыми решениями:

Ребят как переделать метод сортировки пузырьком на метод сортировки простым выбором
public void SortPuzirek(int mass, int Size) // метод, выполняющий сортировку методом пузырька { int metka, obmen =...

Напечатать список в порядке возрастания, используя метод сортировки пузырьком
Помогите с решением задачи. Известен список спортсменов и результат их прыжков в длину. Напечатать общий список в порядке возрастания,...

Исправить код глупой сортировки
Доброго времени суток! Вынужден просить вас о помощи в решении одной задачи. У меня есть код для реализации сортировки массива методом...

4
Футболист
 Аватар для Goal
533 / 435 / 142
Регистрация: 31.10.2011
Сообщений: 1,010
18.11.2012, 06:49
C#
1
int n = int.Parse(Console.ReadLine());
тут ошибку выдаст только в том случаи, если ты вместо целого числа введеш букву или символ
0
0 / 0 / 0
Регистрация: 16.01.2017
Сообщений: 2
16.01.2017, 18:27
1
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
 public class First
    {
      
        int [] a;
      //  int n;
 
        public First(int n) {
 
            a = new int[n];
            Random rand = new Random();
            for (int i = 0; i < n; i++)
            {
                a[i] = rand.Next(-10, 10);
            }
        }
 
        public string Method1(int n) {
 
           
            string s = "";
            for(int i=0; i < n; i++) {
             //  a[i] += sum;
                 s += Convert.ToString(a[i] + " ") + "";
            }
           
            return s;
        }
 
 
        public string Method1()
        {
            int sum = 0;
            string k = "";
            for (int i = 0; i < a.Length; i++)
            {
                sum += a[i];
            }
            k = Convert.ToString(sum);
            return k;
        }
 
 
public partial class Form1 : Form
    {
        public First first;
        public Form1()
        {
            InitializeComponent();
 
        }
 
        private void button1_Click(object sender, EventArgs e)
        {
            int n = Convert.ToInt32(textBox1.Text);
           first = new First(n);
           textBox2.Text = first.Method1(n);
         
 
        }
 
        private void button2_Click(object sender, EventArgs e)
        {
         
            textBox2.Text = first.Method1();
           
        }
    }
0
 Аватар для Pro100Tom
154 / 31 / 11
Регистрация: 29.10.2012
Сообщений: 397
16.01.2017, 19:06
Что-то вы намудрили.

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
//Rextester.Program.Main is the entry point for your code. Don't change it.
//Compiler version 4.0.30319.17929 for Microsoft (R) .NET Framework 4.5
 
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text.RegularExpressions;
 
namespace Rextester
{
    public class Program
    {
        public static void Main(string[] args)
        {
            var numbers = new int[] { 4, 9, 11, 1, 3, 7, 17, 34, 29, 61, -12, 2, -6, 42};
            DisplayNumbers(numbers);
            
            var count = numbers.Length - 1;
            
            for (int i = 0; i < numbers.Length - 1; i++, count--)
            {
                for (int j = 0; j < count; j++)
                {
                    int firstNumber = numbers[j];
                    int secondNumber = numbers[j + 1];
                    
                    if (secondNumber < firstNumber)
                    {
                        numbers[j] = secondNumber;
                        numbers[j + 1] = firstNumber;
                    }
                }
            }
            
            Console.WriteLine();
            DisplayNumbers(numbers);
        }
        
        public static void DisplayNumbers(int[] numbers)
        {
            for (int i = 0; i < numbers.Length; i++)
            {
                Console.WriteLine(numbers[i]);
            }
        }
    }
}
Если хотите считывать с клавиатуры, то используйте метод TryParse.

Вот визуализация метода сортировкки Bubble Sort.
Ещё люблю вот эту.
0
6 / 6 / 0
Регистрация: 31.05.2015
Сообщений: 59
17.01.2017, 13:57
Если из консоли получаешь число, то для преобразования строки в число лучше использовать
Int32.TryParse
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.01.2017, 13:57
Помогаю со студенческими работами здесь

Исправить код и вывод сортировки
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace ConsoleApplication1 { ...

Расширяющий метод: исправить код
В файлах - страница из книги и результат работы программы. Мой код: using System; class MainEntryPoint { static void...

Метод сортировки пузырьком C++
Мне нужно составить функцию сортировки массива в матрице. Я написал, все хорошо. Только вот одна проблемка. Эта функция не трогает первый...

Метод сортировки пузырьком
Здравствуйте. Такая ситуация, мне нужно создать программу для сортировки массива методом пузырька, с помощью генератора случайных чисел. Я...

Как модифицировать метод сортировки пузырьком в шейкерную?
Здравствуйте, только начинаю изучать, толком не разбираюсь, но срочно надо сделать шейкерную сортировку. Есть код сортировки методом...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru