Форум программистов, компьютерный форум CyberForum.ru

Два новых массива переходов через "0" - C++

Войти
Регистрация
Восстановить пароль
 
TigerSHARC
0 / 0 / 0
Регистрация: 01.03.2010
Сообщений: 24
08.03.2010, 20:36     Два новых массива переходов через "0" #1
имеется массив double x = { 0.2, -0.02, 0.6, 0.98, 0.5, -0.35, 1.5};


необходимо создать код, который создает заполняет два массива
1-й массив типа инт содержит номера элементов окружающих положительный переход через ноль :
для данного массива int y[4] = {2, 3, 6, 7};
2-й массив типа double содержит значения по этим номерам
для данного случая double z[4] = {-0.02, 0.6, -0.35, 1.5};


причём необходимо учесть, что если в массиве x больше переходов через "0" чем 2 то в массивы y и z должны записаться только первые два перехода через ноль.
Т.е. длина массивов y и z должна быть всегда 4 независимо от того сколько раз меняется знак в массиве x.

Буду очень благодарен за помощь.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.03.2010, 20:36     Два новых массива переходов через "0"
Посмотрите здесь:

C++ чем отличается вызов объекта через "." и через "->"
C++ Дано два текстовых фаила. "Склеить" эти фаилы
C++ Ввести из клавиатуры два числа, знак операции между ними и вывести результат, к нажатию "?".
C++ зачем ставить ";"(пустую инструкцию два раза) в цикле for
Два числа, действительное "a" и натуральное "n" вводятся с клавиатуры C++
C++ произведение через "одиного" между min и max, и через 1 цикл
C++ Как сгенерить два массива с неповторяющимися "случайными" точками (X, Y)?
Умножить два больших целых числа по правилу умножения "в столбик" C++
C++ Цикл for: зачем использовать разделитель " ; " два раза?
C++ Два класса: "Студент" и "Курс"
C++ Макрос, который принимает два значения (a, b) и возвращает строку "ab"
C++ Дан массив из "n" элементов.Выполнить добавление элементов "k" в конец массива

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
accept
4838 / 3237 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
09.03.2010, 09:40     Два новых массива переходов через "0" #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
29
30
31
32
33
34
35
36
37
38
#include <stdio.h>
#include <stdlib.h>
 
int main(void) /* ANSI C89 */
{
    double x[] = {
        0.2, -0.02, 0.6, 0.98,
        0.5, -0.35, 1.5, -3.0, 5.0
    };
 
    int y[6] = { 0 };
    double z[6] = { 0.0 };
    int i, j, n, size;
    
    size = sizeof x / sizeof x[0];
    
    n = 0;
    for (i = 0; i < size-1 && (n+1) / 2 < 2; i++)
        if (x[i] < 0.0) {
 
            y[n] = i+1;
            z[n] = x[i];
            n++;
                    
            for (j = i+1; j < size; j++)
                if (x[j] > 0.0) {
                    y[n] = j+1;
                    z[n] = x[j];
                    n++;
                    break;
                }
        }
    
    for (i = 0; i < 6; i++)
        printf("%d %.2f" "\n", y[i], z[i]);
    
    exit(EXIT_SUCCESS);
}
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 <stdio.h>
#include <stdlib.h>
 
int main(void) /* ANSI C89 */
{
    double x[] = {
        0.2, -0.02, 0.6, 0.98,
        0.5, -0.35, 1.5
    };
 
    int y[4] = { 0 };
    double z[4] = { 0.0 };
    int i, j, n, size;
    
    size = sizeof x / sizeof x[0];
    
    n = 0;
    for (i = 0; i < size-1 && (n+1) / 2 < 2; i++)
        if (x[i] < 0.0) {
 
            y[n] = i+1;
            z[n] = x[i];
            n++;
                    
            for (j = i+1; j < size; j++)
                if (x[j] > 0.0) {
                    y[n] = j+1;
                    z[n] = x[j];
                    n++;
                    break;
                }
        }
    
    for (i = 0; i < 4; i++)
        printf("%d %.2f" "\n", y[i], z[i]);
    
    exit(EXIT_SUCCESS);
}
Yandex
Объявления
09.03.2010, 09:40     Два новых массива переходов через "0"
Ответ Создать тему
Опции темы

Текущее время: 08:20. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru