Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.51/75: Рейтинг темы: голосов - 75, средняя оценка - 4.51
 Аватар для winelove
2 / 2 / 0
Регистрация: 10.05.2010
Сообщений: 71

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

11.05.2010, 00:47. Показов 15265. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
1. В одномерном массиве, состоящем из n вещественных элементов, вычислить:
1) минимальный по модулю элемент массива;
2) сумму модулей элементов массива, расположенных после первого элемента, равного нулю.
3) Преобразовать таким образом, чтобы в первой его половине, располагались элементы, стоявшие в четных позициях, а во второй половине – элементы, стоявшие в нечетных позициях.
2. Даны две строки, содержащие не более 100 символов. Строки состоят из слов, разделенных пробелами.
Распечатать все слова из каждой строки, начинающиеся и заканчивающиеся на заданную букву.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.05.2010, 00:47
Ответы с готовыми решениями:

Минимальный по модулю элемент массива
В одномерном массиве, состоящем из n целых элементов,вычислить: 1)минимальный по модулю элемент массива 2)сумму модулей элементов...

Вычислить минимальный по модулю элемент массива
Помогите решить задачу! Наработки есть, но... В одномерном массиве, состоящем из n целых элементом, вычислить: 1. Минимальный по модулю...

Найти минимальный по модулю элемент массива
Помогите написать программу. В одномерном массиве, состоящем из n целых элементов, вычислить: 1) минимальный по модулю элемент массива;

13
11.05.2010, 01:06

Не по теме:

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

0
 Аватар для winelove
2 / 2 / 0
Регистрация: 10.05.2010
Сообщений: 71
11.05.2010, 01:08  [ТС]
1 задачу я уже решила, необходимо решить вторую задачу
0
 Аватар для usernet009
26 / 26 / 5
Регистрация: 28.12.2009
Сообщений: 85
11.05.2010, 01:13
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;
}
Зря писал =\
3
 Аватар для winelove
2 / 2 / 0
Регистрация: 10.05.2010
Сообщений: 71
11.05.2010, 01:17  [ТС]
да нет, не зря, спасибо большое, у тебя даже понятней расписано
0
1552 / 918 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
11.05.2010, 07:35
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, мои извинения, думал код только для первой)
1
 Аватар для usernet009
26 / 26 / 5
Регистрация: 28.12.2009
Сообщений: 85
11.05.2010, 19:41
Цитата Сообщение от neske Посмотреть сообщение
usernet009, мои извинения, думал код только для первой)
Хмм.... не понял за что извенения, но... извиняю
0
 Аватар для winelove
2 / 2 / 0
Регистрация: 10.05.2010
Сообщений: 71
03.06.2010, 11:02  [ТС]
C++
1
#define n 10
и
C++
1
#include<cmath>
что это за библиотеки????

Добавлено через 5 минут
и я когда запускаю пишет неизвестный символ n
0
1552 / 918 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
03.06.2010, 11:18
C++
1
#define n 10
Замените на:
C++
1
const int n=10;
раз он не видит.
В начале функции main ().

О всех библиотеках можете прочитать тут: http://www.cplusplus.com/reference/
Там же есть и cmath.
0
 Аватар для winelove
2 / 2 / 0
Регистрация: 10.05.2010
Сообщений: 71
03.06.2010, 11:23  [ТС]
не в ту тему написала=))
0
1552 / 918 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
03.06.2010, 11:23
Потому что нужно использовать теги выделения кода.
0
302 / 160 / 62
Регистрация: 27.02.2010
Сообщений: 317
03.06.2010, 11:36
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;
}
0
 Аватар для winelove
2 / 2 / 0
Регистрация: 10.05.2010
Сообщений: 71
03.06.2010, 11:43  [ТС]
я пользовалась поиском, но мне нужно чтоб задача была написана более простым языком, для начинающих
например я понятия не имею что это:
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);
0
Эксперт С++
 Аватар для CyBOSSeR
2348 / 1721 / 149
Регистрация: 06.03.2009
Сообщений: 3,675
03.06.2010, 18:27
Цитата Сообщение от 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.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
03.06.2010, 18:27
Помогаю со студенческими работами здесь

Найти минимальный по модулю элемент массива
В одномерном массиве, состоящем из n целых элементов, вычислить: 1) минимальный по модулю элемент массива; 2) сумму модулей...

Найти минимальный по модулю элемент массива
Помогите пожалуйста,нужно создать программу,но не представляю,как это сделать,буду очень благодарна! В одномерном массиве, состоящем из n...

Вычислить минимальный по модулю элемент массива
Привет всем :) помогите пожалуйста решить две задачки: 1. В одномерном массиве, состоящем из n целых элементов, вычислить: ...

Вычислить минимальный по модулю элемент массива
Составить программы на двух языках программирования C + + и Pascal В одномерном массиве, состоящий из n целых элементов, вычислить: ...

Вычислить минимальный по модулю элемент массива
Выполнить следующее задание, оформив каждый пункт в виде функции. Все необходимые дан-ные для функций должны передаваться им в качестве...


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru