Не все ветви кода возвращают значение - C# (184435)

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

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

Помогите исправить ошибки, или подкиньте идеи как ещё можно выполнить задание. Мне нужно было написать функцию, возвращающую номера строк матрицы с элементом, который больше суммы остальных элементов в этой же строке.
Листинг программы
  1. static void Main(string[] args)
  2. {
  3. int n, m;
  4. Console.Write("Введите кол-во строк матрицы X: ");
  5. n = int.Parse(Console.ReadLine());
  6. Console.Write("Введите кол-во столбцов матрицы X: ");
  7. m = int.Parse(Console.ReadLine());
  8. int[,] X = new int[n, m];
  9.  
  10. Random rnd = new Random();
  11. nomer(n, m, X);
  12. Console.ReadKey();
  13. }
  14. public static int nomer(int n, int m, int[,] X)
  15. {
  16. int a;
  17. Random rnd = new Random();
  18. for (int i = 0; i < n; i++)
  19. {
  20. for (int j = 0; j < m; j++)
  21. {
  22. X[i, j] = rnd.Next(100);
  23. Console.Write(" {0,3}", X[i, j]);
  24. }
  25. Console.WriteLine();
  26. }
  27. Console.WriteLine();
  28. int max, S;
  29. for (int i = 0; i < n; i++)
  30. {
  31. S = 0;
  32. max = 0;
  33. for (int j = 0; j < m; j++)
  34. {
  35. S = S + X[i, j];
  36. if (X[i, j] > max) max = X[i, j];
  37.  
  38. // Console.WriteLine(" В {0}-й строке максимальный элемент = {1}", i + 1, max);
  39. S = S - max;
  40. //Console.WriteLine("Сумма элементов {0}-й строки не считая максимальный = {1}", i + 1, S);
  41.  
  42. if (max > S)
  43.  
  44. Console.WriteLine("В {0} строке есть элемент, который больше суммы остальных в этой же строке: {1}", i + 1, max);
  45. a = i + 1;
  46. return a;
  47.  
  48. }
  49.  
  50. }
  51. }

Решение задачи: «Не все ветви кода возвращают значение»

textual
Листинг программы
  1. int[,] lm = { { 1, 2, 4 }, { 5, 6, 7 }, { 8, 9, 18 } };
  2.             int kt = lm.GetLength(0);
  3.             int kl = lm.GetLength(1);
  4.             List<int> rows = new List<int>();//список строк, соответствующих условию
  5.             string str = "";
  6.             for (int q = 0; q < kt; q++)
  7.             {
  8.                 int [] df = new int[kl];
  9.                 for (int w = 0; w < kl; w++)
  10.                     df[w] = lm[q, w];
  11.                 int max = df.Max();
  12.                 int sum = df.Sum();
  13.                 if (max > (sum - max)) { rows.Add(q); str += q.ToString() + " "; }
  14.             }
  15.             if (rows.Count > 0) MessageBox.Show(str);

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


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

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

14   голосов , оценка 3.786 из 5

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

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

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