Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/15: Рейтинг темы: голосов - 15, средняя оценка - 4.80
1 / 1 / 0
Регистрация: 30.03.2015
Сообщений: 20

Как удалить в массиве цифру

17.05.2015, 06:40. Показов 3057. Ответов 17
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. В моей предыдущей теме, я решил задачу Как найти в массиве цифру. И теперь мне нужно сделать похожую задачу.

Условие:
Определить, имеется ли в массиве целых чисел A1, A2, ... , An цифра(-ы) 0. Если они есть, то удалить все нули и вывести на экран.

Этот код ищет 0 в массиве.
C++
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
# include <iostream>
 
using namespace std;
 
void main()
{
int x[10] = { 5121, 125, 123, 4551, 1106, 6043, 874, 23, 456, 512 }, i, f, v;
system("color 1F");
for (i = 0; i < 10; i++)
{
cout << x[i] << " ";
cout << endl;
}
for (i = 0, f = 0; i < 10 && f == 0; i++)
{
v = x[i];
while (v != 0)
{
if (v % 10 == 0)
{
f = 1;
cout << "Excellent = " << endl; 
break; 
}
else 
v = v / 10;
}
}
if (f == 0)
cout << "No " << endl;
else
cout << "Yes " << endl;
system("pause");
}
Заранее спасибо.
1
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
17.05.2015, 06:40
Ответы с готовыми решениями:

Из натурального трехзначного числа удалить заданную цифру. Число и цифру вводить с клавиатуры
Из натурального трехзначного числа удалить заданную цифру. Число и цифру вводить с клавиатуры.

Задана некоторая последовательность нечетной длины из нулей и единиц. Из нее разрешается удалить одну цифру. Какую цифру
Последовательность из нулей и единиц четной длины назовем справедливой, если на четных местах этой последовательности столько же единиц,...

Как найти в массиве цифру
Помогите решить задачу, вот уже целый семестр парюсь и не знаю как решить. 1. Среди N треугольников, у которых известна одна сторона и...

17
Dimension
595 / 463 / 223
Регистрация: 08.04.2014
Сообщений: 1,710
17.05.2015, 07:13
Цитата Сообщение от Annonnim Посмотреть сообщение
я решил задачу
прям таки вы решили..
0
 Аватар для Dennis Ritchie
555 / 148 / 58
Регистрация: 27.07.2014
Сообщений: 2,446
17.05.2015, 08:02
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <vector>
#include <iostream>
#include <iterator>
#include <algorithm>
 
int main() {
 
    std::vector<int> v = { 0, 1, 2, 0, 6, 0, 0, 0, 4, 0 };
 
    v.erase(std::remove(v.begin(), v.end(), 0), v.end());
 
    std::copy(v.begin(), v.end(),
        std::ostream_iterator<int>(std::cout, " "));
    std::cout << std::endl;
 
    return 0;
}
Output1 2 6 4
1
1 / 1 / 0
Регистрация: 30.03.2015
Сообщений: 20
18.05.2015, 13:18  [ТС]
Dimension, ну да вы правы. Но задача была сделана не по условию, я слегка подправил.

Dennis Ritchie, спасибо за ответ. Но я даже не знаю что такое #include <iterator>
#include <algorithm>. Не могли бы вы сделать по моему шаблону описанная выше и по проще.
0
 Аватар для Dennis Ritchie
555 / 148 / 58
Регистрация: 27.07.2014
Сообщений: 2,446
18.05.2015, 14:06
Цитата Сообщение от Annonnim Посмотреть сообщение
Если они есть, то удалить все нули и вывести на экран.
Annonnim, проблема в том, что из обычного массива C++, насколько я знаю, нельзя удалять элементы, поэтому нужно использовать vector из STL. Обычные массивы C++ - это всего лишь наследие C, которое нужно стараться не использовать в C++. На обычных массивах ваша проблема может быть решена с помощью создания нового массива, в который можно скопировать элементы, отличные от нуля.

Это массив на стеке (в него нельзя вставлять или удалять из него элементы):
C++
1
int arr[] = { 5121, 0, 123, 0, 1106, 0, 874, 0, 456, 0 };
Это массив на куче (для него имеются полезные функции, в том числе вставка и удаление элементов):
C++
1
std::vector<int> vec = { 5121, 0, 123, 0, 1106, 0, 874, 0, 456, 0 };
Цитата Сообщение от Annonnim Посмотреть сообщение
Не могли бы вы сделать по моему шаблону описанная выше и по проще.
Так подойдёт?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <vector>
#include <iostream>
 
int main() {
 
    std::vector<int> vec = { 5121, 0, 123, 0, 1106, 0, 874, 0, 456, 0 };
 
    int vecLen = vec.size();
    for (int idx = 0; idx < vecLen; ++idx) {
        if (vec[idx] == 0) {
            vec.erase(vec.begin() + idx);
            vecLen = vec.size();
        }
    }
 
    for (auto x : vec) {
        std::cout << x << ' ';
    }
 
    std::cout << std::endl;
 
    return 0;
}
Output5121 123 1106 874 456
0
Dimension
595 / 463 / 223
Регистрация: 08.04.2014
Сообщений: 1,710
18.05.2015, 14:34
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
using namespace std;
int Reverse(int x){
    int y = 1;
    while (x)
        y = x % 10 + y * 10, x /= 10;
    return y;
 
}
int main(){
    int x[10] = { 5121, 125, 123, 4551, 1106, 6043, 874, 23, 456, 512 };
    for (int i = 0; i < 10; i++){
        int t = x[i];
        t = Reverse(t);
        while (t>1){
            if (t % 10 != 0)
                cout << t % 10;
            t /= 10;
        }
        cout << " ";
    }
return 0;
}
1
365 / 321 / 219
Регистрация: 21.02.2013
Сообщений: 756
19.05.2015, 12:32
C++
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
#include <iostream>       // std::cout
using namespace std;
int remove_value(int* arr, int& sz, int val)
{
    int last = sz-2, tmpsz = sz;
    arr[sz-1]== val? sz-- : last++;
  for(int i = 0; i != tmpsz; i++)
  {
      for(int j = i; j < tmpsz-1; j++){
          if(arr[j]== val)
          {
             while(j < last)
             {
                 arr[j]= arr[j+1];
                 j++;
             }
             sz--;
 
          }
      }
 
  }
  return sz;
}
int main ()
{
    const int sz = 12;
  int x[sz] = { 2, 125, 0, 4551, 1106, 0, 0, 0, 456, 0, 9, 67 };
  int size = sz, val = 0;
  size = remove_value(x, size, val);
  for(int i = 0; i != size; i++)
  {
      cout << x[i] << " ";
  }
 
 
  return 0;
}
0
1 / 1 / 0
Регистрация: 30.03.2015
Сообщений: 20
22.05.2015, 05:32  [ТС]
Dennis Ritchie, jurok_85 все равно к сожалению еще тяжело.
Dimension, ваш код прекрасен, но не могли вы бы все добавить в один int main()?

Есть еще идеи? Мне нужен срочно ответ, желательно до завтра. Заранее спасибо.
0
1373 / 596 / 199
Регистрация: 02.08.2011
Сообщений: 2,886
22.05.2015, 13:01
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <iostream>
 
using namespace std;
 
int main()
{
 int v[] = { 0, 1, 2, 0, 6, 0, 0, 0, 4, 0 };
 //int v[] = { 2, 1, 2, 1, 6, 22, 2, 1, 4, 1 };
 int size=sizeof(v)/sizeof(int);
 int count=0;
 
 for (int i=0;i<size-1;i++)   if (v[i]) v[count++]=v[i];
 
 if (size==count+1) {
        cout<<"zero's not founded";
        return 0;
 }
 
 for (int i=0;i<count;i++) cout<<v[i]<<"  ";
 
 
}
1
Заблокирован
22.05.2015, 13:17
C#
1
2
3
int init[10] = {1,2,3,4,5,0,4};
    vector<int> result;
    std::remove_copy(init, init + 10, back_inserter(result), 0);
0
11 / 11 / 5
Регистрация: 01.04.2015
Сообщений: 120
22.05.2015, 13:23
Bertuw, если вас не затруднит я только начина учить вектора, правильно ли я понял ?

C++
1
2
3
int init[10] = {1,2,3,4,5,0,4};// инициализцаия массива с 10 элементов ? 
    vector<int> result;// инициализация вектора тип int он будет с 0 элементов ? 
    std::remove_copy(init, init + 10, back_inserter(result), 0);// тут непонятно прокоменнтируйте пожалуйста
0
Dimension
595 / 463 / 223
Регистрация: 08.04.2014
Сообщений: 1,710
22.05.2015, 22:33
Цитата Сообщение от Annonnim Посмотреть сообщение
ваш код прекрасен, но не могли вы бы все добавить в один int main()?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <bits/stdc++.h>
using namespace std;
 
int main(){
    int x[10] = { 5121, 125, 123, 4551, 1106, 6043, 874, 23, 456, 512 };
    for (int i = 0; i < 10; i++){
        int t = x[i];
        int y = 1;
        while (t){
            y = t % 10 + y * 10, t /=10;
        }
        while (y>1){
            if (y% 10 != 0)
                cout << y % 10;
            y /= 10;
        }
        cout << " ";
    }
    return 0;
}
1
1 / 1 / 0
Регистрация: 30.03.2015
Сообщений: 20
28.05.2015, 14:33  [ТС]
Dimension, к сожалению мой преподаватель сказал что ваш код, не выполняет условие задачи. Как я понял, вы просто скрыли "0", а не удалили.
Жду еще ваших ответов.
0
Dimension
595 / 463 / 223
Регистрация: 08.04.2014
Сообщений: 1,710
28.05.2015, 14:39
Цитата Сообщение от Annonnim Посмотреть сообщение
Жду еще ваших ответов
да ,я скрыл,но этот код легко переделать под замену элемента в массиве
0
1 / 1 / 0
Регистрация: 30.03.2015
Сообщений: 20
28.05.2015, 15:29  [ТС]
Dimension, хорошо. Покажите как.
0
Dimension
595 / 463 / 223
Регистрация: 08.04.2014
Сообщений: 1,710
28.05.2015, 15:48
Лучший ответ Сообщение было отмечено Annonnim как решение

Решение

на самом деле было бы не плохо если бы вы сами поняли как
Кликните здесь для просмотра всего текста
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
int main(){ 
    int x[10] = { 5121, 125, 123, 4551, 1106, 6043, 874, 23, 456, 512 },f=0;
    for (int i = 0; i < 10; i++){
        int t = x[i];
        int y = 0;
        int temp = 0;
        while (t){
            y = t % 10 + y * 10, t /= 10;
        }
        while (y){
            if (y % 10 != 0)
                temp =temp*10 + y % 10,f=1;
            y /= 10;
        }
        if (f)
            x[i] = temp;
        f = 0;
    }
    for (int i = 0; i < 10; i++)cout << x[i] << " ";
    return 0;
}
1
1 / 1 / 0
Регистрация: 30.03.2015
Сообщений: 20
28.05.2015, 16:38  [ТС]
Dimension, я конечно понимаю. Но завтра последний день сдачи вот этой курсовой работы . У меня сейчас много фронтов, и я не успеваю вот везде как следует подготовиться.
0
1373 / 596 / 199
Регистрация: 02.08.2011
Сообщений: 2,886
28.05.2015, 17:04
Кликните здесь для просмотра всего текста
C++
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
#include <iostream>
#include <math.h>
 
using  std::cout;
 
int main(){
    int x[10] = { 5121, 125, 123, -4551, 0, 6043, -874, 23, 456, 512 },y,z,k,f(0);
 
    for (int i=0;i<10;i++){
        if (x[i]<0) {
            x[i]=-x[i];
            f=1;
        }
 
        if (x[i]==0) y=1; else    y=int(log10(float(x[i])))+1;
        z=0;
 
        while(y--){
            k=int(x[i]/pow(float(10),y))%10;
            if (k && !z) z+=k;
            else if (k && z) z=z*10+k;
 
        }
 
        if (f) x[i]=-z;
        else x[i]=z;
        f=0;
 
    }
 
    for (int i=0;i<10;i++) cout<<x[i]<<"  ";  //если x[i]==0, то скрывать. если надо.
 
 
    std::cin.get();
    return 0;
}


Dimension, а отрицательные числа в массиве не числа, над ними можно издеваться?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.05.2015, 17:04
Помогаю со студенческими работами здесь

Как удалить из числа первую и последнюю цифру?
Как удалить из числа первую и последнюю цифру?

Как удалить первую и последнию цифру из числа?
Например, было 287543, стало 8754

Как сделать через класс? Дано число. Удалить из числа первую и последнюю цифру
...

Как составить подстановочный знак в Word, чтобы заменить любую цифру на цифру с точкой и пробел?
В большом тексте каждое предложение пронумеровано одно и многозначными цифрами, по порядку. Но после цифр нет пробелов и текст сливается -...

Как удалить числа от K до L массиве?
Console.Write(&quot;Введите размер массива: &quot;); int mas = int.Parse(Console.ReadLine()); int massive = new int; ...


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

Или воспользуйтесь поиском по форуму:
18
Ответ Создать тему
Новые блоги и статьи
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-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru