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

При вводе массива, на консоль выводятся совершенно одинаковые большие числа

24.12.2014, 13:35. Показов 1183. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
При вводе массива, в 4м задании на консоль выводятся совершенно одинаковые большие числа.
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
#include <iostream>
#include <conio.h>
#include <math.h>
#include <time.h>
#include <fstream>
 
using std::cout;
using std::cin;
using std::endl;
using std::ifstream;
 
 
const int N=100;
 
unsigned int mac1(int n, int A[])
{
    int a,b;
    cout << "Введите границы массива через пробел: ";
    cin >> a >> b;
    unsigned srand(time(NULL));
        {
            for (int i=0; i<n; i++){A[i]=rand()%(b-a+1)+a;}
            cout << endl;
            for (int i=0; i<n; i++){cout << i+1 << " Элемент массива = " << A[i] << endl;}
        }
    return 1;
}
int mac2(int n, int A[])
{
    cout << "Введите " << n << " элементов массива через пробел: ";
    for (int i=0; i<n; i++) cin >> A[i];
    cout << endl << "Вы ввели следующий массив: " << endl;
    cout << endl;
    for (int i=0; i<n; i++) {cout << i+1 << " Элемент массива = " << A[i] << endl;}
    return 1;
}
int mac3(char Name[], int n, int A[])
{
    int x;
    char i;
    ifstream func(Name);
    if (!func) {cout << "Error\n"; return 0;};
    for (i=0; i<n; i++)
        {
            func >> x; A[i]=x;
        }
    func.close();
    cout << endl << "Вы ввели следующий массив: " << endl;
    cout << endl;
    for (i=0; i<n; i++) {cout << i+1 << " Элемент массива = " << A[i] << endl;}
    return 1;
}
 
void main(void)
{
    setlocale(LC_ALL, "Russian"); 
    int n, mac,ex, A[N], B[N], C[N];
    cout << "\t\t\t\tЗадание №1" << endl << endl;
    cout << "Введите размер матрицы: ";
    cin >> n;
    while (n<1 || n>N)
        {
            cout << "Вы ввели неккоректный размер матрицы. Размер матрицы должен быть от 1 до " << N << " " << endl;
            cout << "Введите размер матрицы: ";
            cin >> n;
        }
    cout << endl;
    cout << "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~" << endl;
    cout << "Способы заполнения массива:" << endl;
    cout << "1. С помощью датчика случайных чисел." << endl;
    cout << "2. Ввод значений с клавиатуры." << endl;
    cout << "3. Заполнение из файла." << endl;
    cout << "0. Завершение работы." << endl;
    cout << "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~" << endl;
    cout << "Выберите способ заполнения массива: ";
    cin >> mac;
    switch (mac)
        {
            case 1: mac1 (n, A); break;
            case 2: mac2 (n, A); break;
            case 3: mac3 ("Output.txt", n, A); break;
            case 0: system("exit");
            default: if (mac !=0) cout << "Нет такого варианта";
        }
 
    cout << endl << "\t\t\t\tЗадание №2" << endl;
    int c=0;
    double sum=0.0;
    for (int i=0; i<n; i++)
        {
            if (A[i]<0)
            {
                sum=sum+A[i];
                c=c+1;
            }
        }
    if (c !=0) cout << "Среднее арифметическое отрицательных элементов массива равно " << (sum/c) << endl;
    else cout << "В данном массиве нет отрицательных элементов" << endl;
 
    cout << endl << "\t\t\t\tЗадание №3" << endl;
    int n2=0;
    int i2=0;
    for (int i=0; i<n; i++)
        {
            if (A[i]>9 && A[i]<100)
            {
                B[i2]=A[i];
                n2=n2+1;
                i2=i2+1;
                for (int j=i; j<n-1; j++)
                    A[j]=A[j+1];
                i--;
                n--;
            }
        }
    for (int i=0; i<n; i++) cout << i+1 << " Элемент массива = " << A[i] << endl;
    cout << endl;
    for (int i2=0; i2<n2; i2++) cout << i2+1 << " Элемент массива = " << B[i2] << endl;
    
    cout << endl << "\t\t\t\tЗадание №4" << endl;
    int max=A[0];
    int i3=0, n3=2;
    for (int i=1; i<n; i++) if (max<A[i]) max=A[i];
    cout << "Максимальный элемент первого массива: " << max << endl;
    for (int i2=0; i2<n2; i2++)
        {
            C[i3]=B[i2]; i3++;
            if (B[i2]>0)
            {
                C[i3]=max; i3++;
            }
        }
    for (int i=0; i<i3; i++) cout << i+1 << " Элемент массива = " << C[i3] << endl;
 
    cout << endl << "\t\t\t\tЗадание №5" << endl;
    cout << "Размер первого массива " << n << endl;
    cout << "Размер второго массива " << n2 << endl;
    if (n>n2)
    {
        cout << "Сортируем первый массив" << endl;
        for (int i=0; i<n; i++){
            for (int j=0; j<n-i-1; j++){
                if (A[j]>A[j+1]){
                    int tmp=A[j]; A[j]=A[j+1]; A[j+1]=tmp;
                }
            }
        }
        for (int i=0; i<n; i++) cout << i+1 << " Элемент массива = " << A[i] << endl;
    }
    else
    {
        cout << "Сортируем второй массив" << endl;
        for (int i2=0; i2<n2; i2++){
            for (int j=0; j<n2-i2-1; j++){
                if (B[j]>B[j+1]){
                    int tmp=B[j]; B[j]=B[j+1]; B[j+1]=tmp;
                }
            }
        }
        for (int i2=0; i2<n2; i2++) cout << i2+1 << " Элемент массива = " << B[i2] << endl;
    }
    cout << endl;
    cout << "\t\t\t\tПрограмма завершена.";
    _getch();
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.12.2014, 13:35
Ответы с готовыми решениями:

При выводе массива на консоль выводятся также и большое отрицательное число
Задание: Преобразовать массив целых чисел Х по следующему правилу: элементы массива Х циклически сдвинуть на k позиций влево. Массив...

Закрывается консоль при вводе первого элемента массива
ребят, когда ввожу первый элемент массива, то закрывается консоль! что не так? program Project2; {$APPTYPE CONSOLE} uses ...

Выводятся большие отрицательные числа
В функции max двумерный массив переводится сначала в одномерный, при выводе одномерного массива вместо правильных элементов выводятся...

1
272 / 266 / 146
Регистрация: 02.08.2012
Сообщений: 609
24.12.2014, 15:06
BaZzilio, два варианта, либо массив пуст, либо наблюдается выход за границы массива.
Не знаю ваш ход мыслей, но мне кажется, что в 130-ой строчке инкремент i3 лишний.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.12.2014, 15:06
Помогаю со студенческими работами здесь

Числа выводятся на консоль в виде -1.#IO
Прилагаю код. При изменении точности вывода меняются лишь буквы- -1.#IND, -1.#IND0, -1. #IND00 и т. д. Что это значит, почему они не...

При выгрузке из БД выводятся одинаковые книги
Здравствуйте! Возникла задача, как сгруппировать значения из БД, если допустим выводится информация по одной и той же записи, но с...

Почему при вводе числа программа работает нормально, а при вводе буквы уходит в бесконечный цикл?
void mainmenu() { cout &lt;&lt; &quot;Введи число&quot; &lt;&lt; endl; cin &gt;&gt; choice; if (choice == 1) { cout &lt;&lt; &quot;Hello&quot; &lt;&lt; endl; } ...

Операции с разными числовыми типами. Если на вход подаются большие числа (типа 1000), то выводятся нули
Решил одну задачу, на вход подаются 3 числа (через пробел) выводятся 2 с плавающей точкой. Все работает хорошо, только если на вход...

Вывести массив, притом что одинаковые числа выводятся один раз
Есть массив с некоторыми элементами и некоторые из них повторяются, нужно вывести этот массив, притом что одинаковые числа выводятся один...


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

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

Новые блоги и статьи
CQRS (Command Query Responsibility Segregation) на Java
Javaican 12.05.2025
CQRS — Command Query Responsibility Segregation, или разделение ответственности команд и запросов. Суть этого архитектурного паттерна проста: операции чтения данных (запросы) отделяются от операций. . .
Шаблоны и приёмы реализации DDD на C#
stackOverflow 12.05.2025
Когда я впервые погрузился в мир Domain-Driven Design, мне показалось, что это очередная модная методология, которая скоро канет в лету. Однако годы практики убедили меня в обратном. DDD — не просто. . .
Исследование рантаймов контейнеров Docker, containerd и rkt
Mr. Docker 11.05.2025
Когда мы говорим о контейнерных рантаймах, мы обсуждаем программные компоненты, отвечающие за исполнение контейнеризованных приложений. Это тот слой, который берет образ контейнера и превращает его в. . .
Micronaut и GraalVM - будущее микросервисов на Java?
Javaican 11.05.2025
Облачные вычисления безжалостно обнажили ахиллесову пяту Java — прожорливость к ресурсам и медлительный старт приложений. Традиционные фреймворки, годами радовавшие корпоративных разработчиков своей. . .
Инфраструктура как код на C#
stackOverflow 11.05.2025
IaC — это управление и развертывание инфраструктуры через машиночитаемые файлы определений, а не через физическую настройку оборудования или интерактивные инструменты. Представьте: все ваши серверы,. . .
Инъекция зависимостей в ASP.NET Core - Практический подход
UnmanagedCoder 11.05.2025
Инъекция зависимостей (Dependency Injection, DI) — это техника программирования, которая кардинально меняет подход к управлению зависимостями в приложениях. Представьте модульный дом, где каждая. . .
Битва за скорость: может ли Java догнать Rust и C++?
Javaican 11.05.2025
Java, с её мантрой "напиши один раз, запускай где угодно", десятилетиями остаётся в тени своих "быстрых" собратьев, когда речь заходит о сырой вычислительной мощи. Rust и C++ традиционно занимают. . .
Упрощение разработки облачной инфраструктуры с Golang
golander 11.05.2025
Причины популярности Go в облачной инфраструктуре просты и одновременно глубоки. Прежде всего — поразительная конкурентность, реализованная через горутины, которые дешевле традиционных потоков в. . .
Создание конвейеров данных ETL с помощью Pandas
AI_Generated 10.05.2025
Помню свой первый опыт работы с большим датасетом — это была катастрофа из неотформатированных CSV-файлов, странных значений NULL и дубликатов, от которых ехала крыша. Тогда я потратил три дня на. . .
C++ и OpenCV - Гайд по продвинутому компьютерному зрению
bytestream 10.05.2025
Компьютерное зрение — одна из тех технологий, которые буквально меняют мир на наших глазах. Если оглянуться на несколько лет назад, то сложно представить, что алгоритмы смогут не просто распознавать. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru