Простая сортировка массива, с использованием входного и выходного файла - C#

Узнай цену своей работы

Формулировка задачи:

Добрый день. Задача: дан массив целых чисел - отсортировать его в порядке неубывания.

Формат входного файла

В первой строке входного файла содержится число n (1 ≤ n ≤ 10000) — число элементов в массиве. Во второй строке находятся n целых чисел, по модулю не превосходящих 109.

Формат выходного файла

В выходной файл надо вывести этот же массив в порядке неубывания. Между любыми двумя числами должен стоять ровно один пробел. Пример:
smallsort.in smallsort.out
10  
1 8 2 1 4 7 3 2 3 6 1 1 2 2 3 3 4 6 7 8

И вот мой код:

Листинг программы
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. using System.IO;
  7. namespace ConsoleApplication1
  8. {
  9. class Program
  10. {
  11. static void Main()
  12. {
  13. string text = File.ReadAllText(@"smallsort.in");
  14. String[] numberStrings = text.Split(' ');
  15. long[] values = new long[numberStrings.Length];
  16. for (short i = 1; i < numberStrings.Length; i++)
  17. {
  18. values[i] = long.Parse(numberStrings[i]);
  19. }
  20. Array.Sort(values);
  21. using (StreamWriter sr = new StreamWriter(@"smallsort.out"))
  22. {
  23. for (short i = 1; i < values.Length; ++i)
  24. {
  25. sr.Write(values[i]);
  26. if (i + 1 == values.Length)
  27. {
  28. sr.WriteLine();
  29. }
  30. else
  31. {
  32. sr.Write(' ');
  33. }
  34. }
  35. }
  36. }
  37. }
  38. }
Вроде бы всё правильно, сортируется как надо, но при проверке выходного файла ответ почему-то не засчитывается. В чем ошибка?

Решение задачи: «Простая сортировка массива, с использованием входного и выходного файла»

textual
Листинг программы
  1. string text = File.ReadAllText(@"smallsort.in");
  2. string[] numberStrings = text.Split(new char[] { ' ' }, StringSplitOptions.RemoveEmptyEntries);
  3.  
  4. int valuesCount = int.Parse(numberStrings[0]); // <<< количество элементов в массиве
  5.  
  6. long[] values = new long[valuesCount]; // <<< создание массива длиной valuesCount
  7.  
  8. for (int index = 0; index < valuesCount; ++index)
  9. {
  10.     values[index] = long.Parse(numberStrings[index + 1]); // <<< заполнение массива
  11. }
  12.  
  13. Array.Sort(values); // <<< сортировка массива
  14.  
  15. // ... дальше просто выводим values в файл smallsort.out (опять же, индексация values начинается с нуля)

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

8   голосов , оценка 3.375 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут
Похожие ответы