Поиск в массиве. Ошибка "Оператор "&&" не может применяться к операндам типа "bool" и "double"" - C#

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

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

Найти номер последнего минимального элемента среди положительных четных элементов, лежащих правее первого отрицательного элемента. В 24 строке :Ошибка 3 Оператор "&&" не может применяться к операндам типа "bool" и "double" , я почему-то думал что вопрос можно решить банально скобками, но...
Листинг программы
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. namespace _6
  7. {
  8. class Program
  9. {
  10. static void Main(string[] args)
  11. {
  12. bool b = false;
  13. string s;
  14. int min = -1;
  15. Console.WriteLine("Qty of elements");
  16. s = Console.ReadLine();
  17. int n = int.Parse(s);
  18. double[] a = new double[n];
  19. Console.WriteLine("Enter the number: ");
  20. for (int i = 0; i < a.Length; i++)
  21. {
  22. if (a[i] < 0) b = true;
  23. if ((b == true)&&(a[i] > 0) && (a[i] % 2) && (a[min] > a[i])) min = i;
  24. }
  25. Console.WriteLine("минимальный элемент массива {0} /t его номер {1}", a[min], min);
  26. }
  27. }
  28. }

Решение задачи: «Поиск в массиве. Ошибка "Оператор "&&" не может применяться к операндам типа "bool" и "double""»

textual
Листинг программы
  1. using System;
  2.  
  3. namespace _2
  4. {
  5.     class Program
  6.     {
  7.         static void Main(string[] args)
  8.         {
  9.             int[] a = { 1, 4, 7, -6, 0, -3, 8, -5, 1, 4, 0, 2, -2 };
  10.             int firstNegativeIndex = Array.FindIndex(a, x => x < 0);
  11.             if (firstNegativeIndex < 0)
  12.             {
  13.                 Console.WriteLine("Нет отрицательных элементов!");
  14.                 return;
  15.             }
  16.             if (firstNegativeIndex == a.Length - 1)
  17.             {
  18.                 Console.WriteLine("Нет элементов после первого отрицательного!");
  19.                 return;
  20.             }
  21.             int minIndex = Array.FindIndex(a, firstNegativeIndex + 1, x => (x > 0 && x%2==0));
  22.             if (minIndex < 0)
  23.             {
  24.                 Console.WriteLine("Нет четных положительных элементов после первого отрицательного!");
  25.                 return;
  26.             }
  27.             for (int i = minIndex+1; i < a.Length; i++)
  28.             {
  29.                 if (a[i] <= a[minIndex] && a[i] > 0 && a[i]%2==0)
  30.                     minIndex = i;
  31.             }
  32.             Console.WriteLine("Это номер: " + minIndex);
  33.         }
  34.     }
  35. }

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


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

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

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

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

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

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