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

Минимальный по модулю элемент массива - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 17, средняя оценка - 4.65
winelove
 Аватар для winelove
1 / 1 / 0
Регистрация: 10.05.2010
Сообщений: 71
11.05.2010, 00:47     Минимальный по модулю элемент массива #1
1. В одномерном массиве, состоящем из n вещественных элементов, вычислить:
1) минимальный по модулю элемент массива;
2) сумму модулей элементов массива, расположенных после первого элемента, равного нулю.
3) Преобразовать таким образом, чтобы в первой его половине, располагались элементы, стоявшие в четных позициях, а во второй половине – элементы, стоявшие в нечетных позициях.
2. Даны две строки, содержащие не более 100 символов. Строки состоят из слов, разделенных пробелами.
Распечатать все слова из каждой строки, начинающиеся и заканчивающиеся на заданную букву.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ISergey
11.05.2010, 01:06
  #2

Не по теме:

winelove, Название темы должно отражать ее суть!

winelove
 Аватар для winelove
1 / 1 / 0
Регистрация: 10.05.2010
Сообщений: 71
11.05.2010, 01:08  [ТС]     Минимальный по модулю элемент массива #3
1 задачу я уже решила, необходимо решить вторую задачу
usernet009
 Аватар для usernet009
24 / 24 / 1
Регистрация: 28.12.2009
Сообщений: 85
11.05.2010, 01:13     Минимальный по модулю элемент массива #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
#define n 10
#include<iostream>
#include<cmath>
using namespace std;
/*1. В одномерном массиве, состоящем из n вещественных элементов, вычислить:
1) минимальный по модулю элемент массива;
2) сумму модулей элементов массива, расположенных после первого элемента, равного нулю.
3) Преобразовать таким образом, чтобы в первой его половине, располагались элементы, стоявшие в четных позициях, а во второй половине – элементы, стоявшие в нечетных позициях.
*/
int main()
{   
    float arr[n]= {0}; // создаем массив размера n
    for ( int i=0; i<n; i++) // вводим массив
        cin>>arr[i];
    float min = abs(arr[0]);
    for ( int i=0; i<n; i++) // находим минимальный элемент массива и пишем его в min
        if ( min > abs(arr[i]) )
            min = abs(arr[i]);
    float sum=0;
    for ( int i=0; i<n; i++)
        if ( arr[i] == 0 )
        {
            for ( int j=i; j<n; j++)
                sum = sum + abs(arr[j]);
            break;
        }
    float tmpArr[n]; // создаем временный массив в который будем "упорядочивать" элементы
    for ( int i=0, j=0; i<n; i=i+2, j++ ) // записываем в левую часть нечетные элементы
        tmpArr[j] = arr[i];
    for ( int i=1, j=n/2; i<n; i=i+2, j++ ) // записываем в правую часть четные элементы
        tmpArr[j] = arr[i];
    cout<<endl;
    for ( int i=0; i<n; i++) // копируем временный массив в arr и выводим все на экран
    {
        arr[i] = tmpArr[i];
        cout<<arr[i];
    }
    cout<<"min = "<<min<<endl;
    cout<<"sum = "<<sum<<endl;
    system("pause");
    return 0;
}
Зря писал =\
winelove
 Аватар для winelove
1 / 1 / 0
Регистрация: 10.05.2010
Сообщений: 71
11.05.2010, 01:17  [ТС]     Минимальный по модулю элемент массива #5
да нет, не зря, спасибо большое, у тебя даже понятней расписано
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,689
11.05.2010, 07:35     Минимальный по модулю элемент массива #6
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 <iostream>
#include <iomanip>
 
int main ()
{
    const int size=10;
    int MAS[size]={9,4,1,0,-2,11,15,3,9,15};
 
    std::cout << "Start matrix:\n";
    for (int i=0; i<size; i++)
        std::cout << std::setw(3) << MAS[i];
 
    int first_null=-1;
    for (int i=0; i<size; i++)
        if (!(MAS[i])) {
            first_null=i;
            break; }
 
    std::cout << std::endl;
    if (first_null==-1) std::cout << "Zero element not found!.\n";
    else {
        int sum=0;
        for (int i=first_null+1; i<size;i++)
            sum+=abs(MAS[i]);
            std::cout << "Sum: " << sum << std::endl; }
 
    return 0;
}
10$ )

Добавлено через 3 минуты
usernet009, мои извинения, думал код только для первой)
usernet009
 Аватар для usernet009
24 / 24 / 1
Регистрация: 28.12.2009
Сообщений: 85
11.05.2010, 19:41     Минимальный по модулю элемент массива #7
Цитата Сообщение от neske Посмотреть сообщение
usernet009, мои извинения, думал код только для первой)
Хмм.... не понял за что извенения, но... извиняю
winelove
 Аватар для winelove
1 / 1 / 0
Регистрация: 10.05.2010
Сообщений: 71
03.06.2010, 11:02  [ТС]     Минимальный по модулю элемент массива #8
C++
1
#define n 10
и
C++
1
#include<cmath>
что это за библиотеки????

Добавлено через 5 минут
и я когда запускаю пишет неизвестный символ n
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,689
03.06.2010, 11:18     Минимальный по модулю элемент массива #9
C++
1
#define n 10
Замените на:
C++
1
const int n=10;
раз он не видит.
В начале функции main ().

О всех библиотеках можете прочитать тут: http://www.cplusplus.com/reference/
Там же есть и cmath.
winelove
 Аватар для winelove
1 / 1 / 0
Регистрация: 10.05.2010
Сообщений: 71
03.06.2010, 11:23  [ТС]     Минимальный по модулю элемент массива #10
не в ту тему написала=))
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,689
03.06.2010, 11:23     Минимальный по модулю элемент массива #11
Потому что нужно использовать теги выделения кода.
NNN777
299 / 157 / 19
Регистрация: 27.02.2010
Сообщений: 317
03.06.2010, 11:36     Минимальный по модулю элемент массива #12
winelove, На форуме полно однотипных задач - могли бы и поиском воспользоваться ...
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#include <iostream>
#include <stdlib.h>
#include <stdio.h>
using namespace std;
const int SIZE =100;
 
char *pr2 (char *in);
char *pr1 (char *in);
char *copy(char *, char *, int);
void form (char *a, char, char *out);
 
int main()
{
    char buf[SIZE]={'\0'}, outbuf[SIZE]={'\0'}, p;
 
    cout<<"Vvedite stroky: ";
    cin.getline(buf, SIZE);
    cout<<"Vvedite bukvu: ";    
    cin>>p;
    form(buf, p, outbuf);
 
    cout<<"Rezultat: "<<outbuf;
    cout<<endl<<endl;
}
void form (char *a, char p, char *out)
{   
    char *first=a; 
 
    while (*(first=pr1(a)))
    {
        a=pr2(first);
        if (*first==p&&*(a-1)==p)
            out=copy(first, out, a-first);
        else first=pr2(first);      
    }
}
char *pr1(char *in)
{ 
    while (*in&&(*in==' ')||(*in=='\t'))
        in++;
    return in;
}
char *pr2 (char *in)
{
    while (*in&&*in!=' '&&*in!='\t')
        in++;
    return in;
}
char *copy(char * from, char *to, int len)
{
    for (int j=0; (j<len)&&(*to++=*from++); j++)
        ;   
    *to++=' ';
    *to='\0';
    return to;
}
winelove
 Аватар для winelove
1 / 1 / 0
Регистрация: 10.05.2010
Сообщений: 71
03.06.2010, 11:43  [ТС]     Минимальный по модулю элемент массива #13
я пользовалась поиском, но мне нужно чтоб задача была написана более простым языком, для начинающих
например я понятия не имею что это:
C++
1
2
3
4
char *pr2 (char *in);
char *pr1 (char *in);
char *copy(char *, char *, int);
void form (char *a, char, char *out);
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.06.2010, 18:27     Минимальный по модулю элемент массива
Еще ссылки по теме:

C++ В одномерном массиве, состоящем из n элементов, вычислить минимальный по модулю элемент массива
Вычислить минимальный по модулю элемент массива C++
Динамический массив, найти минимальный по модулю элемент массива C++

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

Или воспользуйтесь поиском по форуму:
CyBOSSeR
Эксперт C++
 Аватар для CyBOSSeR
2293 / 1663 / 86
Регистрация: 06.03.2009
Сообщений: 3,675
03.06.2010, 18:27     Минимальный по модулю элемент массива #14
Цитата Сообщение от winelove Посмотреть сообщение
минимальный по модулю элемент массива;
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <cstdlib>
#include <algorithm>
#include <iostream>
 
bool Compare(int arg1, int arg2) {
  return std::abs(arg1) < std::abs(arg2);
}
 
// Возвращает индекс минимального по модулю элемента массива
int Min(const int* arr, size_t size) {
  return std::min_element(arr, arr + size, Compare) - arr;
}
 
int main() {
  int arr[] = { -10, 2, 4, 2, 2, -1};
  std::cout << Min(arr, sizeof(arr) / sizeof(arr[0])) << std::endl;
  return 0;
}
Результат: http://codepad.org/E69UXvEb

Цитата Сообщение от winelove Посмотреть сообщение
сумму модулей элементов массива, расположенных после первого элемента, равного нулю
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <cstdlib>
#include <algorithm>
#include <iostream>
 
int Sum(int arg1, int arg2) {
  return arg1 + std::abs(arg2);
}
 
int SumAfterZero(const int* arr, size_t size) {
  const int* zero = std::find(arr, arr + size, 0);
 
  return zero == arr + size? 0 : std::accumulate(zero + 1, arr + size, 0, Sum);
}
 
int main() {
  int arr[] = { -10, 0, -4, 2, 12, -1};
  std::cout << SumAfterZero(arr, sizeof(arr) / sizeof(arr[0])) << std::endl;
  return 0;
}
Результат: http://codepad.org/KxCO7RLl

Цитата Сообщение от winelove Посмотреть сообщение
Преобразовать таким образом, чтобы в первой его половине, располагались элементы, стоявшие в четных позициях, а во второй половине – элементы, стоявшие в нечетных позициях
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
#include <cstdlib>
#include <functional>
#include <algorithm>
#include <iterator>
#include <iostream>
 
struct IsInEvenPosition : unary_function<int,bool> {
public:
  IsInEvenPosition() 
  : counter(0) {
  }
 
  bool operator()(int arg) {
    return counter++ % 2 == 0;
  }
 
private:
  int counter;
};
 
int main() {
  int    arr[] = { -10, 0, -4, 2, 12, -1, 5};
  size_t size  = sizeof(arr) / sizeof(arr[0]);
  
  std::stable_partition(arr, arr + size, IsInEvenPosition());
  std::copy            (arr, arr + size, std::ostream_iterator<int>(std::cout, " "));
  
  return 0;
}
Результат: http://codepad.org/8McXbLuo.
Yandex
Объявления
03.06.2010, 18:27     Минимальный по модулю элемент массива
Ответ Создать тему
Опции темы

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