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

Перегрузка типа int и double и сортировка - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 11, средняя оценка - 4.91
sanek9992
0 / 0 / 0
Регистрация: 11.04.2010
Сообщений: 19
19.10.2010, 19:53     Перегрузка типа int и double и сортировка #1
Дано задание: В одномерном массиве состоящем из n элементов вычислить:
1 номер минимального по модулю элемента.
2 сумму модулей элементов массива, расположенных после первого отрицательного.
3 сжать массив удалив из него все элементы, величина которых находиться в интервале а.в. Освободившиеся элементы заполнить нулями.
4сделать перегрузку типами int и double
>>>Вопрос у меня такой: я сделал первые три задания, но нули в третьем у меня не переместились в конец масива.. нужна ваша помощь уважаемые программисты) помогите переделать Пожалуйста
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
39
40
41
42
#include<iostream.h>
#include<stdio.h>
#include<stdlib.h>
void main()
{
    int a[10]= {-2,4,-6,1,2,7,-8,9,2,3};
  int i, min, k=0, ot, s=0, z, b;
  for(i=0; i<10; i++)
            cout<< "  " <<a[i];
            cout<<"\n";
 
            for(i=0; i<10; i++)
            if(abs(min)>abs(a[i])) min=a[i];
            for(i=0; i<10; i++)
           {
             k++;
             if(min==a[i]) break;
           }
          
            cout<< "Homer Min = " <<k;
            cout<< "  " <<"\n";
           {
            for(i=0; i<10; i++)
            if(a[i]<0) {ot=i; break;}
            for(i=ot; i<10; i++) s+=abs(a[i]);            
           }
            cout<<" S mod = " <<s;
            cout<<"  " <<"\n";
           {
            cout<< "  "<< "interv A- ";
            cin>> z;
            cout<< "  "<< "interv b- ";
            cin>> b;
 
            for(i=1; i<10; i++)
            {
              if(i>=z && i<=b) a[i]=0;
              cout <<'  '<<a[i];
            }
            }
            cout<< "  " <<"\n";
}
Добавлено через 1 час 28 минут
Помогите пожалста!! Заранее благодарен.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Andrew_Lvov
Эксперт C++
 Аватар для Andrew_Lvov
259 / 189 / 5
Регистрация: 19.08.2010
Сообщений: 758
Записей в блоге: 1
19.10.2010, 20:24     Перегрузка типа int и double и сортировка #2
2 вопрос - очевидно имеется ввиду, что всё должно выполняться в функции. Она должна быть определена для типа int, и для double - то есть принимать указатель на массив из соотв. элементов.
sanek9992
0 / 0 / 0
Регистрация: 11.04.2010
Сообщений: 19
19.10.2010, 20:25  [ТС]     Перегрузка типа int и double и сортировка #3
да. только я не понимаю как это нужно переделать=\
besstiaa
 Аватар для besstiaa
93 / 93 / 7
Регистрация: 04.06.2010
Сообщений: 223
19.10.2010, 20:25     Перегрузка типа int и double и сортировка #4
sanek9992, ну видимо тут имеется ввиду создание 2 функций с одинаковым именем, которые выполняют пункты 1-3 для массива типов int и double соответственно.
sanek9992
0 / 0 / 0
Регистрация: 11.04.2010
Сообщений: 19
19.10.2010, 20:26  [ТС]     Перегрузка типа int и double и сортировка #5
ребят т.е будет 6 так сказать подпрограм 3 для инт и 3 для дабл? как это будет выглядеть можете написать на одном примере?
Andrew_Lvov
Эксперт C++
 Аватар для Andrew_Lvov
259 / 189 / 5
Регистрация: 19.08.2010
Сообщений: 758
Записей в блоге: 1
19.10.2010, 20:40     Перегрузка типа int и double и сортировка #6
Можно сделать шаблонную ф-цию, где шаблонным аргументом является тип данных, int или double в данном случае.

Добавлено через 1 минуту
for(i=1; i<10; i++)
Индексы массивов в С/С++ начинаются с нуля.
besstiaa
 Аватар для besstiaa
93 / 93 / 7
Регистрация: 04.06.2010
Сообщений: 223
19.10.2010, 20:47     Перегрузка типа int и double и сортировка #7
Что-то подобное.
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 <iostream>
#include <cmath>
using namespace std;
 
static const int size = 10;
 
void FindMin (double arr[]);
void FindMin (int arr[]);
 
int main()
{
    int a[size]= {-2,4,-6,1,2,7,-8,9,2,3};
    double b[size] = {10.1, -1.5, 2.0, 2.4, -34.4, 2.9, -0.9, 1.9, 1.0, -345.5 };
    FindMin(a);
    FindMin(b);
 
    system("Pause");
    return 0;
}
 
void FindMin (double arr[])
{
    int index = 0;
    double min = abs(arr[0]);
    for (int i = 1; i < size; i++)
        if ( abs(arr[i]) < min)
        {
            min = abs(arr[i]);
            index = i;
        }
    cout << " Index = " << index << endl;
}
void FindMin (int arr[])
{
    int index = 0;
    int min = abs(arr[0]);
    for (int i = 1; i < size; i++)
        if ( abs(arr[i]) < min)
        {
            min = abs(arr[i]);
            index = i;
        }
    cout << " Index = " << index << endl;
}
sanek9992
0 / 0 / 0
Регистрация: 11.04.2010
Сообщений: 19
19.10.2010, 20:49  [ТС]     Перегрузка типа int и double и сортировка #8
т.е перегрузки выполняют одно и тоже действие только разными способами.

Добавлено через 14 секунд
я думаю так да?
besstiaa
 Аватар для besstiaa
93 / 93 / 7
Регистрация: 04.06.2010
Сообщений: 223
19.10.2010, 20:51     Перегрузка типа int и double и сортировка #9
sanek9992,в зависимости от того какого типа массив передается в качестве аргумента функции FindMin выполняется та или иная функция.
sanek9992
0 / 0 / 0
Регистрация: 11.04.2010
Сообщений: 19
19.10.2010, 20:52  [ТС]     Перегрузка типа int и double и сортировка #10
спасибо. Более менее понял разберусь сейчас. Можно еще вопрос?) Как использовать допустим на тех же трех заданиях шаблоны функ-ий?
besstiaa
 Аватар для besstiaa
93 / 93 / 7
Регистрация: 04.06.2010
Сообщений: 223
19.10.2010, 20:56     Перегрузка типа int и double и сортировка #11
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 <iostream>
#include <cmath>
using namespace std;
 
static const int size = 10;
 
template <typename T>
void FindMin (T arr[])
{
    int index = 0;
    T min = abs(arr[0]);
    for (int i = 1; i < size; i++)
        if ( abs(arr[i]) < min)
        {
            min = abs(arr[i]);
            index = i;
        }
    cout << " Index = " << index << endl;
}
 
int main()
{
    int a[size]= {-2,4,-6,1,2,7,-8,9,2,3};
    double b[size] = {10.1, -1.5, 2.0, 2.4, -34.4, 2.9, -0.9, 1.9, 1.0, -345.5 };
    FindMin(a);
    FindMin(b);
 
    system("Pause");
    return 0;
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
19.10.2010, 20:57     Перегрузка типа int и double и сортировка
Еще ссылки по теме:

Напишите перегруженную функцию power (), которая принимает два целочисленных параметра типа int и возвращает целочисленное значение типа int C++
Перегрузка функции int double C++
Вывести элементы массива, находящихся между его min и max. Перегрузка функций для int и double C++

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

Или воспользуйтесь поиском по форуму:
sanek9992
0 / 0 / 0
Регистрация: 11.04.2010
Сообщений: 19
19.10.2010, 20:57  [ТС]     Перегрузка типа int и double и сортировка #12
сейчас разберусь. А по поводу того чтобы все нули в моей программе переместить в конец массива как это сделать?

Добавлено через 14 секунд
з.ы Спасибо за примеры шаблонов и перегрузок
Yandex
Объявления
19.10.2010, 20:57     Перегрузка типа int и double и сортировка
Ответ Создать тему
Опции темы

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