Форум программистов, компьютерный форум, киберфорум
Наши страницы

Нужно из массива удалить нулевые элементы - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Выход по Esc из любого места программы http://www.cyberforum.ru/cpp-beginners/thread377134.html
Привет! Изучаю С++ на примере создания консольной программы. Типа - ввели данные, вывели данные. Вопрос - а как выйти из программы в любом месте по нажатию Escape? Можно конечно перед...
C++ Полиморфизм и освобождение памяти class A{ // базовый класс ... }; class B : public A{ // унаследованный от класса A ... }; далее в программе: B *b = new B; http://www.cyberforum.ru/cpp-beginners/thread377122.html
C++ Для матрицы размером m x n вычислить сумму элементов матрицы
Доброго всем времени! Есть задачка: Для матрицы размером m x n вычислить сумму элементов матрицы. Умножить на это число элементу k-той строки. Значение k вводится. Исходная матрица задается...
C++ Массив указателей на строки
Здравствуйте! В общем нужно передать в функцию массив строк (чистый C) Как правильнее это сделать и в дальнейшем обработать в самой функции. Примерно так: void func (char *p) {} или void func...
C++ Подскажите пожалуйста какие ошибки здесь есть - или что не соблюдено. http://www.cyberforum.ru/cpp-beginners/thread377078.html
Доброе утро! Я начинаю только осваивать программирование.Читаю - решаю задачи - пытаюсь разбираться в ошибках. Написал программу с циклами - идея такая - вводят оценки от 0 до 100...
C++ Приложение WinApi на C++ После компиляции выводит следующее сообщение "Необработанное исключение в "0x7672828c" в "Диспетчер.exe": 0xC0000005: Нарушение прав доступа при чтении "0xcccccccc"." подробнее

Показать сообщение отдельно
Байт
Эксперт C
16533 / 10803 / 1637
Регистрация: 24.12.2010
Сообщений: 20,823
03.11.2011, 14:44
Байт, разве что короче, но не всегда эффективнее. Если в массиве нет нулевых элементов, то в вашем алгоритме лишнее перезаписывание всего массива произойдет. Или в массиве один нулевой элемент, то тоже тот алгоритм эффективнее. Все от ситуации зависит.
Да, у вас очень хороший алгоритм, но его можно оптимизировать до ОПТИМАЛЬНОГО в любом случае алгоритма) То есть из него можно сделать алгоритм, улучшить который будет уже нельзя для произвольного массива.
Понял. Попробуем так
C
1
2
for(m=i=flag=0; i<n; i++) 
  if (a[i]!='0' && flag)  { a[m++] = a[i]; flag=1; }
Так пойдет? Или совершенству нет предела?
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru