0 / 0 / 0
Регистрация: 19.04.2016
Сообщений: 2
1

Первое и последнее положительные числа массива

19.04.2016, 11:23. Показов 4975. Ответов 4

Массив заполняем рандомными числами от -10 до 5. Надо вывести на экран сумму первого и последнего пложительного. Java
На данный момент смог заполнить рандомными числами и вывести положительные все. Но как дошло до поиска первого и последнего - зашел в тупик.

Ноль можно считать как за положительное.

Java
1
2
3
4
5
6
7
8
9
10
11
int[] array = new int[30];
      int x = 0;
      int counter = 0;
      for (int i = 0; i < array.length; i++) {
        array[i] = (int) (Math.random() * 16) - 10;
        if (array[i] > 0) {
            System.out.println(array[i]);
        }
 
        }
    }
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
19.04.2016, 11:23
Ответы с готовыми решениями:

Поменять первое и последнее слово в строке местами (string.split)
Используя метод split класса String нужно поменять в строке первое и последнее слово.Не...

Напишите программу выводящую положительные числа одномерного массива
Напишите программу выводящую положительные числа одномерного массиваΩ

Прочитать строки из файла и поменять местами первое и последнее слово в каждой строке, записать в тот же файл
Это программа поменяет местами первое и последнее слово в строке. Но не могу понять что означает...

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

4
8 / 8 / 6
Регистрация: 11.04.2016
Сообщений: 75
19.04.2016, 12:27 2
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
int[] array = new int[30];
      int first= 0, last = 0;
      int x = 0;
      int counter = 0;
      for (int i = 0; i < array.length; i++) {
        array[i] = (int) (Math.random() * 16) - 10;
        if (array[i] >= last) last = array[i];  
        if (array[i] >= 0 && array[i] < first) first = array[i];  
        if (array[i] > 0) {
            System.out.println(array[i]);
        }
 
        }
 
    System.out.println("first: " + first);
    System.out.println("last: " + last);
    }
0
18 / 18 / 13
Регистрация: 18.06.2015
Сообщений: 79
19.04.2016, 12:34 3
Лучший ответ Сообщение было отмечено Mrgrey8 как решение

Решение

Цитата Сообщение от Mrgrey8 Посмотреть сообщение
Ноль можно считать как за положительное.
Тогда уж пишите, что вам надо сумму первого и последнего неотрицательного чисел.

Den_Ur, у меня при запуске вашего алгоритма всегда один и тот же ответ:
last positive: 5
first negative: -10

Если верно поняла задание:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
int[] array = new int[30];
   int first=0, last=0;
      
      for (int i = 0; i < array.length; i++) {
        array[i] = (int) (Math.random() * 16) - 10;
        if (array[i] >= 0) {
            System.out.print(array[i]+" ");
        }
        }
      for (int j=0; j<array.length; j++){
           if (array[j]>=0){
              first=array[j];
              break;
          }
      }
      for (int j=array.length-1; j>=0; j--){
          if (array[j]>=0){
              last=array[j];
              break;
          }
      }
      System.out.println("\nПервое положительное число: "+first+", последнее положительное число: "+last+". Сумма чисел: "+(first+last));
1
8 / 8 / 6
Регистрация: 11.04.2016
Сообщений: 75
19.04.2016, 12:44 4
Цитата Сообщение от Aliara Посмотреть сообщение
у меня при запуске вашего алгоритма всегда один и тот же ответ:
last positive: 5
Я поправил код, возможно, вы использовали какой-то из промежуточных вариантов, пока я правил сообщение

Ошибка у меня в коде по невнимательности: я ищу наибольшее значение, а не последнее...
0
0 / 0 / 0
Регистрация: 19.04.2016
Сообщений: 2
20.04.2016, 23:56  [ТС] 5
Aliara, Спасибо большое! Отличное решение.
Я сам додумался сделать по другому. Я решил воспользоватся инверсией массива.
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
  int [] array = new int [30];
            int k = array.length - 1;
            int x = 0;
            int y = 0;
            for(int i = 0; i < array.length; i++){
                array[i] = (int)(Math.random()*16)-10;
                if(array[i] > 0){
                    x = array[i];
                    System.out.println(x);
                }
            }
            for(int i = 0; i < array.length / 2; i++){
                int buf = array[i];
                array[i] = array[k];
                array[k] = buf;
                k--;
            }
 
            for(int i = 0; i < array.length; i++){
                if(array[i] > 0){
                    y = x + array[i];
                }
            }
            System.out.println(y + "!!!");
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
20.04.2016, 23:56
Помогаю со студенческими работами здесь

Найти последнее неотрицательное число в массиве и разделить на него положительные числа массива
В результате не выдает результат деления. Дан одномерный массив чисел {Ai}, i =1...14. Найти...

Определить первое по порядку нечетное и последнее четное числа
Задание 1 Создать типизированный файл целых чисел. Записать в него с консоли последовательность...

Определить первое и последнее пропущенные числа и их позиции в ряду
Здравствуйте! Дан фрагмент натурального ряда чисел, в котором некоторые числа отсутствуют. ...

В файле найти первое положительное и последнее отрицательное числа
Есть программа, которая в файле находит первое положительное и последнее отрицательное числа и...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru