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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Iliabobr
3 / 3 / 1
Регистрация: 04.11.2009
Сообщений: 98
#1

В одномерном массиве найти сумму целых частей елементов, расположенных после последнего отрицательного элемента - C++

11.04.2011, 01:32. Просмотров 988. Ответов 3
Метки нет (Все метки)

Здорова)) вот такая вот весчица)
в одномерном массиве надо подсчитать:
1. количество елементов меньше С (// ну ето не надо сам сделаю)))
2. сумму целых частей елементов , расположенных после последнего отрицательнлгл елемента.
3.Ну и преобразовать массив таким образом, чтоб сначала располагались все елементы, отличающиеся от максимального не более чем на 20 процентов, а потом асе остальные
третий пункт хотя бы подскажите а то я воббще не прикидываю даже как его делать
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
#include<iostream.h>
 
template<class T> T max(T *a, int m, int n);
int nuts(int **a, int m, int n);
int nuts1(int **a, int m, int n);
 
int main()
{
    int **a=NULL;
    int m, n;
    int i, h =0;
    cout<<"Vvod razmernosti"<<endl;
    cout<<"m: ";
    cin>>m;
    cout<<"n: ";
    cin>>n;
    a= new int *[m];
 
    cout<<"Vvod matricy iz "<<m;
    cout<<" strok i "<<n<<" stolbov: ";
    cout<<endl;
    for(i=0;i<m;i++)
    {
        a[i]=new int [n];
        for (int j=0; j<n; j++)
            cin>>a[i][j];
    }
    for (i=0;i<m;i++)
    {
        cout<<endl;
        for (int j=0; j<n;j++)
            cout<<a[i][j]<<"  ";
    }
    cout<<"Chislo strok bez '0' : "<<nuts(a,m,n)<<'\n';
    cout<<endl;
    cout<<"Naib. chislo: "<<nuts1(a,m,n)<<'\n';// else cout<<"Net povtorov"<<'\n';
    cout<<endl;
    delete[] a;
    return 0;
}
int nuts(int **a, int m, int n)
{
    int h;
    h=0;
    for(int i=0;i<m;i++)
    {
        for(int j=0;j<n;j++)
            if(a[i][j]==0) break;
            if(j==n) h++;
    }
    return h;
}
int nuts1(int **a, int m, int n)
{
    int max=0; //bool fl=false;
    for (int i=0; i<m;i++)
        for (int j=0; j<n;j++)
            if ((/*fl && */a[i][j]>max)/* || (!fl)*/)
            {
                for (int l=0; l<m; l++)
                    for (int p=0;p<n;p++)
                        if (a[l][p]==a[i][j] && (l!=i ||p!=j))
                        {
                    //      if(!fl) fl=true;
                            max=a[i][j];
                            l=m;
                            break;
                        }
                    //  cout<<"\n";
                    //  if (fl===true) cout <<"Naib. chislo:  "<<
            }
                        return max;
            }
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.04.2011, 01:32     В одномерном массиве найти сумму целых частей елементов, расположенных после последнего отрицательного элемента
Посмотрите здесь:

Вычислить сумму целых частей элементов массива, расположенных после последнего отрицательного C++
C++ Найти в одномерном массиве сумму элементов массива, расположенных до последнего положительного
В одномерном массиве посчитать сумму элементов после последнего положительного элемента C++
C++ В одномерном массиве, состоящем из 30 целых элементов, вычислить сумму элементов массива, расположенных после последнего элемента, равного нулю.
C++ В одномерном массиве вычислить сумму элементов, расположенных после максимального элемента
В одномерном целочисленном массиве вычислить сумму элементов, расположенных после минимального элемента C++
Найти сумму элементов, расположенных правее последнего отрицательного элемента C++
Вычислить сумму целых частей элементов массива, расположенных после последнего отрицательного элемента C++
В одномерном массиве вычислить: максимальный элемент массива и сумму элементов массива, расположенных до последнего положительного элемента C++
В одномерном массиве (использовать vector) подсчитать сумму элементов после последнего положительного элемента C++
Вычислить сумму элементов массива, расположенных после последнего отрицательного элемента C++
C++ Вычислить сумму целых частей элементов массива расположенных после последнего отрицательного элемента

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
igorrr37
1614 / 1242 / 124
Регистрация: 21.12.2010
Сообщений: 1,899
Записей в блоге: 7
11.04.2011, 02:29     В одномерном массиве найти сумму целых частей елементов, расположенных после последнего отрицательного элемента #2
Цитата Сообщение от Iliabobr Посмотреть сообщение
преобразовать массив таким образом, чтоб сначала располагались все елементы, отличающиеся от максимального не более чем на 20 процентов, а потом асе остальные
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
#include<iostream>
#include<algorithm>
#include<cmath>
 
bool IsIn20(const int& max, const int& val){
    return fabs(max-val)<=fabs(float(max)/5);
}
 
int main(){
    int mas[]={21, 4, 5, 22, 18, 17, 19, -7, -22}, size=sizeof(mas)/sizeof(*mas), max, i, j, tmp;
    max=*std::max_element(mas, mas+size);
    for(i=0; i<size; i++){
        if(IsIn20(max, mas[i])){
            tmp=mas[i];
            for(j=i-1; j>=0&&!IsIn20(max, mas[j]); --j){
                mas[j+1]=mas[j];
            }
            mas[j+1]=tmp;
        }
    }
    for(int i=0; i<size; i++){
        std::cout<<mas[i]<<" ";
    }
    return 0;
}
Iliabobr
3 / 3 / 1
Регистрация: 04.11.2009
Сообщений: 98
12.04.2011, 03:36  [ТС]     В одномерном массиве найти сумму целых частей елементов, расположенных после последнего отрицательного элемента #3
с третим спс разобрался) а какой функцией мене брать целую часть елемента?

Добавлено через 2 минуты
ой, програмку я зря вставил, ето лекая вообще))

Добавлено через 32 секунды
левая то есть
Valerko
17 / 17 / 1
Регистрация: 30.11.2010
Сообщений: 164
12.04.2011, 08:25     В одномерном массиве найти сумму целых частей елементов, расположенных после последнего отрицательного элемента #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
#include <iostream>
#include <сmath>
 
#define n 6
using namespace std;
void bubble_sort(float[]);
void elementC(float[]);
void summa(float[]);
int main()
{
int i, c;
float a[n];
for(i=0; i<n; i++)//ввод массива
    {
    cout<<i+1<< " : ";
    cin>> a[i];
    }
 
int imax=0,left = 0, right=n;//imax-  номер макс. элемента
float proc=0;
for (i = 1; i < n; i++)
    if(a[i] > a[imax]) 
        imax = i;
cout << "max = " <<a[imax] << endl;//вывод макс. элем
proc = a[imax]*0.2;// 20% от макс. числа
float boundle=a[imax]-proc; //макс-0
 //вывод этого 
cout << "20 % = " <<proc << endl;
elementC(a);
summa(a);
bubble_sort(a);
system("pause");
return 0;
}
void elementC(float s[])
{
int c;
cout<<"vvedite c = ";//ввод С
cin>>c;
int k=0;//счетчик эл. больших С
for (int i=0;i<n;i++)
    if (s[i]<c) 
        k++;
cout<<"kollichestvo = "<<k<<endl;
}
void summa(float s[])
{
int iotr=0,i;//нахождение последнего отриц. элемента
for (i = 0; i < n; i++)
    if(s[i] < 0) 
        iotr = i;
cout <<"otr = " << s[iotr]<<endl;
 
float sum=0;//сумма от послед отриц до конда
for (i=iotr+1;i<n;i++)
    sum+=(int)s[i];
cout<<"symma = "<<sum<<endl;
}
 
void bubble_sort(float s[])//сортировка
{
int i,t,mid;
float max,swap;
for(i=0;i<n;i++)
{
max=s[i];
mid=i;
for(t=(i+1);t<n;t++)
{
    if(s[t]>max) 
    {   
    mid=t; 
    max=s[t];
    }
}
        swap=s[i];
        s[i]=s[mid];
        s[mid]=swap;
}
for(i=0;i<n;i++)
    cout<<s[i]<<"   ";
}
3й пункт реализован как сортировка пузырьком))
P.S. программа написана мной только частично, сильно не пинайте
Yandex
Объявления
12.04.2011, 08:25     В одномерном массиве найти сумму целых частей елементов, расположенных после последнего отрицательного элемента
Ответ Создать тему
Опции темы

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