С Новым годом! Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.85/40: Рейтинг темы: голосов - 40, средняя оценка - 4.85
0 / 0 / 0
Регистрация: 06.01.2019
Сообщений: 52

Количество итераций цикла

29.09.2019, 21:51. Показов 8668. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет, не могу разобраться как вывести количество итераций цикла if. Пробую через сделать это через вспомогательную переменную count, но выводит нули. Помогите пожалуйста, заранее спасибо

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
25
26
27
28
29
30
31
32
33
34
35
private static void shakerSort(int[] array, String name) {
        int left = 0; // левая граница
        int count2 = 0;
        int right = array.length - 1; // правая граница
        do {
            int count1 = 0;
            //Сдвигаем к концу массива "тяжелые элементы"
            for (int i = left; i < right; i++) {
                if (array[i] > array[i + 1]) {
                    array[i] = array[i + 1];
                    array[i + 1] = array[i];
                    array[i] = array[i + 1];
                    count1++; //тут должно считаться количество итераций цикла if
                }
            }
            right--; // уменьшаем правую границу
            //Сдвигаем к началу массива "легкие элементы"
            for (int i = right; i > left; i--) {
                count2++;
                if (array[i] < array[i - 1]) {
                    array[i] = array[i - 1];
                    array[i - 1] = array[i];
                    array[i] = array[i - 1];
//                    count2++; //тут должно считаться количество итераций цикла if
                }
            }try (PrintWriter pw = new PrintWriter(name)) {
                pw.printf("Number of size: %d, number of swap:%d", count1, count2); //выводит нули
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            }
            left++; // увеличиваем левую границу
        } while (left <= right);
 
        System.out.println(Arrays.toString(array));
    }
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.09.2019, 21:51
Ответы с готовыми решениями:

Сумма результатов итераций цикла for
for (int i = a; i &lt;= b; i++){ System.out.printf(&quot;Значение &quot; + i + &quot; в квадрате равно %.0f \n&quot;, Math.pow(i, 2)); q =(int)...

Задать количество итераций цикла
как сделать так чтоб цикл считал столько раз сколько я ввел? почему выводит ненужные цифры? #include &lt;stdio.h&gt; #include...

Посчитать количество итераций цикла
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;fstream&gt; using namespace std; int main() { setlocale(LC_ALL, &quot;Rus&quot;); ...

12
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
29.09.2019, 22:15
Берешь дебаггер и смотришь, почему нули
0
0 / 0 / 0
Регистрация: 06.01.2019
Сообщений: 52
29.09.2019, 22:31  [ТС]
Цитата Сообщение от xoraxax Посмотреть сообщение
Берешь дебаггер и смотришь, почему нули
смотрю, переменная просто остается нулем, хотя я говорю ей прибавляться на единицу каждую итерацию цикла if
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
29.09.2019, 22:34
Цитата Сообщение от TrueJegor Посмотреть сообщение
int count1 = 0;
Поставь эту строчку перед do {
1
0 / 0 / 0
Регистрация: 06.01.2019
Сообщений: 52
29.09.2019, 22:37  [ТС]
iSmokeJC, пробовал, нули. Пробую засунуть count1 в цикл for и вывести. Показывает много нулей, я так понимаю, мне нужно вытащить количество этих нулей... Или я туплю уже совсем?)
0
Модератор
Эксперт Java
 Аватар для alecss131
2848 / 1356 / 404
Регистрация: 11.08.2017
Сообщений: 4,325
Записей в блоге: 2
29.09.2019, 22:44
Цитата Сообщение от TrueJegor Посмотреть сообщение
array[i] = array[i + 1];
array[i + 1] = array[i];
array[i] = array[i + 1];
Только меня смущают эти строчки? i элементу присваиваем i+1 затирая i, потом в i+1 помещаем тоже самое значение и потом опять повторяем первую строчку, в итоге просто затерли значение i элемента и выполнили 2 пустых действия после
Во втором цикле for тоже самое

Добавлено через 4 минуты
Если это перестановка 2 элементов то надо например так:
Java
1
2
3
int tmp = array[i + 1];
array[i + 1] = array[i];
array[i] = tmp;
1
0 / 0 / 0
Регистрация: 06.01.2019
Сообщений: 52
29.09.2019, 22:45  [ТС]
alecss131, ой, точно. Спасибо, переделал, но проблему не решило
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
29.09.2019, 22:47
Цитата Сообщение от TrueJegor Посмотреть сообщение
Спасибо, переделал,
выкладывай
0
0 / 0 / 0
Регистрация: 06.01.2019
Сообщений: 52
29.09.2019, 22:50  [ТС]
Цитата Сообщение от iSmokeJC Посмотреть сообщение
выкладывай
Java
1
2
3
4
5
6
7
8
9
10
for (int i = left; i < right; i++) {
 
                if (array[i] > array[i + 1]) {
                    tmp = array[i];
                    array[i] = array[i + 1];
                    array[i + 1] = tmp;
                    count1++;
                }
                System.out.println(count1);
            }
0
 Аватар для alicesmagic
233 / 130 / 27
Регистрация: 24.08.2016
Сообщений: 875
29.09.2019, 22:53
Я попробовала сделать вот с таким массивом: int[] array = { 3, 5, 7, 1, 8, 2 };
У меня счетчики получились не нулевые: Number of size: 1, number of swap:6
1
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
29.09.2019, 22:53
Java
1
2
3
4
5
6
7
8
9
10
11
        int count1 = 0;
        for (int i = left; i < right; i++) {
 
            if (array[i] > array[i + 1]) {
                tmp = array[i];
                array[i] = array[i + 1];
                array[i + 1] = tmp;
                count1++;
            }
        }
        System.out.println(count1);
1
0 / 0 / 0
Регистрация: 06.01.2019
Сообщений: 52
29.09.2019, 23:04  [ТС]
alicesmagic, ага, теперь понял, что проблема в массиве. Все хорошо бы, но в консоль выводится уже отсортированный массив, т.е. сортирует правильно, но счетчики не выводит... Надо еще посмотреть. спасибо

Добавлено через 7 минут
Цитата Сообщение от TrueJegor Посмотреть сообщение
ага, теперь понял, что проблема в массиве. Все хорошо бы, но в консоль выводится уже отсортированный массив, т.е. сортирует правильно, но счетчики не выводит... Надо еще посмотреть. спасибо
может потому, что элементы массива даются из файла? или потому что они записаны в столбик, есть догадки у кого?)
0
Модератор
Эксперт Java
 Аватар для alecss131
2848 / 1356 / 404
Регистрация: 11.08.2017
Сообщений: 4,325
Записей в блоге: 2
29.09.2019, 23:09
Попробуйте выводит массив в начале функции
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
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
import java.util.Arrays;
 
public class Sort {
 
    public static void main(String[] args) {
        int mas[] = {11, 3, 5, 7, 1, 8, 2, 9};
        shakerSort(mas, "");
    }
 
    private static void shakerSort(int[] array, String name) {
        System.out.println(Arrays.toString(array));
        int left = 0;
        int count2 = 0;
        int count1 = 0;
        int tmp;
        int right = array.length - 1; 
        do {
            for (int i = left; i < right; i++) {
                if (array[i] > array[i + 1]) {
                    tmp = array[i + 1];
                    array[i + 1] = array[i];
                    array[i] = tmp;
                    count1++; 
                }
            }
            right--;
            for (int i = right; i > left; i--) {
                if (array[i] < array[i - 1]) {
                    tmp = array[i - 1];
                    array[i - 1] = array[i];
                    array[i] = tmp;
                    count2++;
                }
            }
            /*try (PrintWriter pw = new PrintWriter(name)) {
                pw.printf("Number of size: %d, number of swap:%d", count1, count2); //выводит нули
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            }*/
            System.out.printf("Number of size: %d, number of swap:%d\n", count1, count2);
            left++;
        } while (left <= right);
 
        System.out.println(Arrays.toString(array));
    }
 
}
Вот ваш код, с правкой перестановки и count2 внутри if
Только последние шаги одинаковые выводит.
Вот вывод
Code
1
2
3
4
5
6
[11, 3, 5, 7, 1, 8, 2, 9]
Number of size: 7, number of swap:4
Number of size: 8, number of swap:6
Number of size: 8, number of swap:6
Number of size: 8, number of swap:6
[1, 2, 3, 5, 7, 8, 9, 11]
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.09.2019, 23:09
Помогаю со студенческими работами здесь

Посчитать количество итераций цикла
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;fstream&gt; using namespace std; int main() { setlocale(LC_ALL, &quot;Rus&quot;); ...

Как посчитать количество итераций цикла?
Не совсем представляю, как это осуществить. Т.е. возвращается х, а еще что-то вернуть, то будет немного не так, как хотелось бы, по идее....

Не выполняется нужное количество итераций цикла
Добрый день ребята!!!! Помогите найти ошибку!!! //--------------------------------------------------------------------------- ...

Подсчитать количество итераций цикла в единицу времени
Хочу подсчитать производительность проги, зациклив её на час и подсчитав количество итераций. Как это проще всего сделать? Не обязательно...

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


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru