С Новым годом! Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
0 / 0 / 0
Регистрация: 25.01.2014
Сообщений: 56
1

Создать массив В, в который переписать по порядку сначала все положительные, а потом все отрицательные элементы

25.01.2014, 20:48. Показов 1356. Ответов 7
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый вечер! есть 2 несложные задачи, помогите, пожалуйста решить:

Вот одна из них

Задан массив А[10]. Создать массив В, в который переписать по порядку сначала все положительные, а потом все отрицательные элементы.


Заранее благодарю!

 Комментарий модератора 
Создавайте тему в соответствующем разделе. Один вопрос - одна тема.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.01.2014, 20:48
Ответы с готовыми решениями:

Массив: переставить элементы таким образом, чтобы сначала были записаны все положительные, затем все отрицательные, а потом все нули.
Здравствуйте! помогите пожалуйста с задачей по информатике. Буду очень благодарна) В массиве из...

Преобразовать массив: сначала расположить все отрицательные элементы, а потом - все положительные
ЧЕРЕЗ ФУНКЦИЮ! Преобразовать одномерный целочисленный массив таким образом, чтобы сначала...

Преобразовать массив, расположив сначала все положительные элементы, а потом - все отрицательные
Преобразовать массив таким образом, чтобы сначала располагаись все положительные элементы, а...

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

7
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
25.01.2014, 21:33 2
решение "в лоб", сплошная копипаста
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
#include <stdio.h>
 
#define MAX 10
 
int main(int argc, char *argv[])
{
    int a[MAX], b[MAX];
    int i = 0, j = 0;
    
    for( ; i < MAX; i++)
    {
        printf("Введите А%d\n", i + 1);
        scanf("%d", &a[i]);
    }
    
    for(i = 0; i < MAX; i++)
        if(a[i] >= 0)
            b[j++] = a[i];
    
    for(i = 0; i < MAX; i++)
        if(a[i] < 0)
            b[j++] = a[i];
    
    for(i = 0; i < MAX; i++)
        printf("%d ", b[i]);
    
    return 0;
}
0
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
12832 / 7569 / 1764
Регистрация: 25.07.2009
Сообщений: 13,965
25.01.2014, 23:28 3
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
#include <stdio.h>
#include <string.h>
 
#define SIZE 10
 
int main(void) {
    int arr[SIZE] = { 1, -2, -3, 4, 5, -6, 7, -8, -9, 10 }, i = 0, j = SIZE - 1;
 
    while ( i < j ) {
        if ( arr[i] < 0 ) {
            int tmp = arr[i];
            memmove(arr + i, arr + i + 1, sizeof(int) * (j - i));
            arr[j--] = tmp;
        }
        else
            ++i;
    }
 
    for ( i += 1, j = SIZE - 1; i < j; ++i, --j ) {
        int tmp = arr[i];
        arr[i] = arr[j];
        arr[j] = tmp;
    }
 
    for ( i = 0; i < SIZE; ++i )
        printf("%d ", arr[i]);
    printf("\n");
 
    return 0;
}
Если все числа отрицательные, переставляет последний элемент в начало. Поправлять лень, да и вообще вариант бредовый.
0
Клюг
7675 / 3190 / 382
Регистрация: 03.05.2011
Сообщений: 8,380
26.01.2014, 17:24 4
Дык,
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
 
#define SIZE 10
int cmp(const void *op1, const void *op2){
const int *p1 = (const int *) op1;
const int *p2 = (const int *) op2;
return (*p1) < (*p2);
}; 
void main(void) {
    int A[SIZE] = { 1, -2, -3, 4, 5, -6, 7, -8, -9, 10 }, B[SIZE], i;
    memmove(B,A,sizeof(A));
    qsort(B,sizeof(B)/sizeof(int),sizeof(int),cmp);
    for(i=0;i<SIZE;i++) printf("A[%d] = %d\tB[%d] = %d\n\r",i,A[i],i,B[i]);
};
0
KOPOJI
26.01.2014, 17:26
  #5

Не по теме:

Charles Kludge, в таком коде можно докопаться до последовательности выполнения действий..

Цитата Сообщение от toxenok Посмотреть сообщение
в который переписать по порядку сначала все положительные, а потом все отрицательные элементы.
а не переписать все сразу и отсортировать..

0
Charles Kludge
26.01.2014, 17:33
  #6

Не по теме:

Цитата Сообщение от KOPOJI Посмотреть сообщение
в таком коде можно докопаться
Не спорю, создаем промежуточный массив, сортируем, а потом поэлементно переписываем в B[].:jokingly:
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
 
#define SIZE 10
int cmp(const void *op1, const void *op2){
const int *p1 = (const int *) op1;
const int *p2 = (const int *) op2;
return (*p1) < (*p2);
}; 
void main(void) {
    int A[SIZE] = { 1, -2, -3, 4, 5, -6, 7, -8, -9, 10 }, B[SIZE],tmp[SIZE],i = 0, j = SIZE - 1;
    memmove(tmp,A,sizeof(A));
    qsort(tmp,sizeof(tmp)/sizeof(int),sizeof(int),cmp);
    for(i=0;i<SIZE;i++) {B[i] = tmp[i];printf("A[%d] = %d\tB[%d] = %d\n\r",i,A[i],i,B[i]);};
};

0
KOPOJI
26.01.2014, 17:40
  #7

Не по теме:

Charles Kludge, вообще, я намекал на сортировку изначального массива :D

0
Форумчанин
Эксперт CЭксперт С++
8216 / 5046 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
27.01.2014, 15:30 8
А с нулем то что делать?
(у меня сначала записывает все неотрицательные, потом все отрицательные)
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <stdio.h>
#define N 10
 
int main(void)
{
    int A[N] = {1, -2, -3, 4, 5, -6, 7, -8, -9, 10}, B[N], i, j = 0, k = 0;
    for (i=0; i < N; i++)
        if (A[i] >= 0)
            B[j++] = A[i];
    for (i=0; i < N; i++)
    {
        if (A[i] < 0)
            B[j + k++] = A[i];
        printf("%d ", B[i]);
    }
    return 0;
}
1
27.01.2014, 15:30
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
27.01.2014, 15:30
Помогаю со студенческими работами здесь

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

Преобразовать массив, чтобы сначала располагались все положительные элементы, а потом — все отрицательные
Здравствуйте, мне срочно нужна помощь:В одномерном массиве, состоящем из n целых элементов,...

Преобразовать массив, чтобы сначала располагались все положительные элементы, а потом все отрицательные
Помогите исправить ошибку, пожалуйста. Тут 3 задания в одном, ошибка в третьем. Задача 3: Из общего...

Преобразовать массив так, чтобы сначала располагались все отрицательные элементы, а потом все положительные
ребят помогите срочно у мя экзамен!!!!!!!!!!!! Одномерный массив состоит из N вещественных...

Преобразовать массив таким образом, чтобы сначала располагались все положительные элементы, а потом – все отрицательные
В одномерном массиве, состоящем из n целочисленных элементов, вычислить: Преобразовать массив...

преобразовать массив таким образом, чтобы сначала располагались все положительные элементы, а потом — все отрицательные
#include &lt;iostream&gt; using namespace std; int main(){ const int N=10; double x; ...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Блоги программистов
Как перейти с Options API на Composition API в Vue.js
BasicMan 06.01.2025
Почему переход на Composition API актуален В мире современной веб-разработки фреймворк Vue. js продолжает эволюционировать, предлагая разработчикам все более совершенные инструменты для создания. . .
Архитектура современных процессоров
inter-admin 06.01.2025
Процессор (центральный процессор, ЦП) является основным вычислительным устройством компьютера, которое выполняет обработку данных и управляет работой всех остальных компонентов системы. Архитектура. . .
История создания реляционной модели баз данных, правила Кодда
Programming 06.01.2025
Предпосылки создания реляционной модели В конце 1960-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
Полезные поделки на Arduino, которые можно сделать самому
raxper 06.01.2025
Arduino как платформа для творчества Arduino представляет собой удивительную платформу для технического творчества, которая открывает безграничные возможности для создания уникальных проектов. Эта. . .
Подборка решений задач на Python
IT_Exp 06.01.2025
Целью данной подборки является предоставление возможности ознакомиться с различными задачами и их решениями на Python, что может быть полезно как для начинающих, так и для опытных программистов. . . .
С чего начать программировать микроконтроллер­­ы
raxper 06.01.2025
Введение в мир микроконтроллеров Микроконтроллеры стали неотъемлемой частью современного мира, окружая нас повсюду: от простых бытовых приборов до сложных промышленных систем. Эти маленькие. . .
Из чего собрать игровой компьютер
inter-admin 06.01.2025
Сборка игрового компьютера требует особого внимания к выбору комплектующих и их совместимости. Правильно собранный игровой ПК не только обеспечивает комфортный геймплей в современных играх, но и. . .
Обновление сайта www.historian.b­y
Reglage 05.01.2025
Обещал подвести итоги 2024 года для сайта. Однако начну с того, что изменилось за неделю. Добавил краткий урок по последовательности действий при анализе вредоносных файлов и значительно улучшил урок. . .
Как использовать GraphQL в C# с HotChocolate
Programming 05.01.2025
GraphQL — это современный подход к разработке API, который позволяет клиентам запрашивать только те данные, которые им необходимы. Это делает взаимодействие с API более гибким и эффективным по. . .
Модель полного двоичного сумматора с помощью логических операций (python)
AlexSky-coder 04.01.2025
def binSum(x:list, y:list): s=^y] p=x and y for i in range(1,len(x)): s. append((x^y)^p) p=(x and y)or(p and (x or y)) return s x=list() y=list()
Это мы не проходили, это нам не задавали...(аси­­­­­­­­­­­­­­­­­­­­­­­­­­х­р­о­н­­н­­­ы­­й счётчик с управляющим сигналом зад
Hrethgir 04.01.2025
Асинхронный счётчик на сумматорах (шестиразрядный по числу диодов на плате, но наверное разрядов будет больше - восемь или шестнадцать, а диоды на старшие), так как триггеры прошли тестирование и. . .
Руководство по созданию бота для Телеграм на Python
IT_Exp 04.01.2025
Боты для Телеграм представляют собой автоматизированные программы, которые выполняют различные задачи, взаимодействуя с пользователями через интерфейс мессенджера. В данной статье мы рассмотрим,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru