0 / 0 / 0
Регистрация: 30.10.2014
Сообщений: 4

Удалить элементы массива, состоящие из одной цифры, и отсортировать его

25.06.2015, 22:41. Показов 1796. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуй дорогой друг! Спасибо, что зашёл сюда! Передо мной стоит следующая задача:
Дан массив целых чисел из n элементов, заполненный случайным образом числами из заданного пользователем промежутка. Удалить из него все однозначные элементы. Отсортировать получившийся массив и вывести его на экран и в файл.

Часть программы, а именно заполнение массива рандомными числами из диапазона. Но вот понять как сделать удаление однозначных элементов и сортировку не могу. Гуглил и нашел программу на паскале, но опять же переделать не смог, может кто-нибудь в силе переделать программу с паскаля, либо сделать свой вариант?
Заранее премного благодарен.

Это то, что сделал я
C++ (Qt)
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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main(void) {
 
    srand(time(NULL));
    int i,y,x1,x2;
    bool f;
    char s[]=mas[i];
 
    printf("Vvdedute razmer massiva:");
    scanf("%d",&y);
    printf("Vvedute diapozon:\n");
    printf("x1: ");
    scanf("%d",&x1);
    printf("x2: ");
    scanf("%d",&x2);
    int mas[y];
    for(i = 0; i<y;i++) {
        mas[i]=rand()%(x2-x1)+x1;
        printf("%d ", mas[i]);
    }
    printf("\n");
    return 0;
}
А это программа на паскале, которую я пытался переделать:
Pascal
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
const n=10;
var a:array[1..n] of integer;
    i,m,j:integer;
    f:boolean;
    s:string;
begin
for i:=1 to n do
read(a[i]);
i:=1;m:=n;
while i<=m do
 begin
  Str(a[i],s);
  f:=true;
  for j:=1 to length(s) do
   if s[j]<>s[1] then f:=false;
  if f then
            begin
             for j:=i to m-1 do
             a[j]:=a[j+1];
             dec(m);
            end;
  inc(i);
 end;
for i:=1 to m do
 writeln(a[i]);
end.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.06.2015, 22:41
Ответы с готовыми решениями:

Отсортировать элементы массива по убыванию старшей цифры в записи его элементов
1. Отсортировать элементы массива по убыванию старшей цифры в записи его элементов

Отсортировать элементы массива по убыванию старшей цифры в записи его элементов
1. Отсортировать элементы массива по убыванию старшей цифры в записи его элементов помогите написать программу с помощью с++

Удалить из массива элементы, состоящие из одинаковых цифр
дан массив целых чисел (n=10), заполненный случайным образом числами из промежутка . Удалить из него все элементы, которые состоят из...

7
 Аватар для egor2116
584 / 387 / 216
Регистрация: 20.01.2013
Сообщений: 1,169
26.06.2015, 08:13
Наверное как то так
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
#include <iostream>
#include <ctime>
#include <cstdlib>
#include <algorithm>
#include <vector>
 
int min, max;
void inputArr(float & var) { var = rand() % (max - min) + min; }
void printArr(float var) { std::cout << var << " "; }
 
int main(int argc, char** argv) {
    
    size_t SIZE;
    srand(time(0));
    
    std::cout << "Input size array : "; std::cin >> SIZE;
    std::cout << "Input min : "; std::cin >> min;
    std::cout << "Input max : "; std::cin >> max;
    
    std::vector<float> array(SIZE);
    
    std::for_each(array.begin(), array.end(), inputArr);
    std::for_each(array.begin(), array.end(), printArr);
    for(std::vector<float>::iterator i = array.begin(); i != array.end(); ++i)
        if(*i / 10.0 < 1)   
            array.erase(i);
            
    std::cout << std::endl; 
    std::for_each(array.begin(), array.end(), printArr);
    
    std::sort(array.begin(), array.end());
    
    std::cout << std::endl; 
    std::for_each(array.begin(), array.end(), printArr);
    
    return 0;
}
0
0 / 0 / 0
Регистрация: 30.10.2014
Сообщений: 4
26.06.2015, 10:48  [ТС]
Однозначные это состоящие из одной цифры, например есть массив: 1,2,21,22. Удаляются 1 и 2, а 21 и 22 остаются
0
 Аватар для egor2116
584 / 387 / 216
Регистрация: 20.01.2013
Сообщений: 1,169
26.06.2015, 11:21
Однозначные это состоящие из одной цифры, например есть массив: 1,2,21,22. Удаляются 1 и 2, а 21 и 22 остаются
смотри мое сообщение выше
0
0 / 0 / 0
Регистрация: 30.10.2014
Сообщений: 4
26.06.2015, 12:04  [ТС]
egor2116, ваша программа работает идеально, но не сочтите за придирку: ваши познания в си гораздо глубже моих и поэтому не могли бы вы написать код попроще (возможно даже просто до безобразия)?
0
 Аватар для egor2116
584 / 387 / 216
Регистрация: 20.01.2013
Сообщений: 1,169
26.06.2015, 12:13
написать код попроще
нужно на С или С++
например можно использовать вместо printf и scanf
cout и cin ?
0
0 / 0 / 0
Регистрация: 30.10.2014
Сообщений: 4
27.06.2015, 12:00  [ТС]
egor2116, нужно на просто C, желательнее всего использовать printf и scanf
P.S. Оказывается я еще не там тему создал...

Добавлено через 23 часа 35 минут
Сделал сам. Тему можно закрывать.
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
39
40
41
42
43
44
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int cmp(const void *a, const void *b) {
    return *(int*)a - *(int*)b;
}
int main(void) {
 
    srand(time(NULL));
 
    int i,k,j,y,x1,x2;
    printf("Vvdedute razmer massiva:");
    scanf("%d",&y);
    printf("Vvedute diapozon:\n");
    printf("x1: ");
    scanf("%d",&x1);
    printf("x2: ");
    scanf("%d",&x2);
    int mas[y];
    for(i = 0; i<y;i++) {
        mas[i]=rand()%(x2-x1)+x1;
        printf("%d ", mas[i]);
    }
    printf("\n");
    k=0;
    j=0;
    int mas2[y];
    for (i=0;i<y;i++){
        if(mas[i]/10.0>=1){
            mas2[j]=mas[i];
            k++;
            j++;
        }}
    printf("\n");
    printf("rezultat: \n");
    qsort(mas2,y,sizeof(int),cmp);
    for (i=0;i<k;i++){
    printf("%d ",mas2[i]);
    FILE *f=fopen("sort.txt","a");
    fprintf(f,"%d\n",mas2[i]);
    fclose(f);}
 
    return 0;
}
0
 Аватар для Геомеханик
838 / 641 / 940
Регистрация: 26.06.2015
Сообщений: 1,409
27.06.2015, 13:43
Maydayru, проще сделать сортировку в начале далее пройтись до 1-ого двузначного числа и сместить весь массив разом функцией memcpy
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.06.2015, 13:43
Помогаю со студенческими работами здесь

Удалить из массива все элементы, состоящие из одинаковых цифр
3 вариант.

Удалить из одномерного массива все элементы, состоящие из одинаковых цифр
Удалить из одномерного массива все элементы, состоящие из одинаковых цифр. Помогите пожалуйста написать программу) Заранее спасибо)

Удалить из массива все числа, состоящие из одинаковых цифр и упорядочить элементы по убыванию их сумм
Удалить из целочисленного массива все числа, состоящие из одинаковых цифр. Упорядочить элементы массива в порядке убывания суммы их цифр. ...

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

Удалить все нечётные элементы массива и отсортировать
1. Удалить все нечётные элементы массива #include&lt;iostream.h&gt; #include&lt;conio.h&gt; #include&lt;stdlib.h&gt; void main() { clrscr();...


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

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

Новые блоги и статьи
Музыка, написанная Искусственным Интеллектом
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 . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
PowerShell Snippets
iNNOKENTIY21 11.11.2025
Модуль PowerShell 5. 1+ : Snippets. psm1 У меня модуль расположен в пользовательской папке модулей, по умолчанию: \Documents\WindowsPowerShell\Modules\Snippets\ А в самом низу файла-профиля. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru