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

Поменять в матрице местами максимальный и минимальный элементы каждой строки - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ библиотека http://www.cyberforum.ru/cpp-beginners/thread1108531.html
написал программу, которая использует математические функции( например возведение в степень). но она выдает ошибку, не может открыть математ. библиотеку(Cannot open include file: 'сmath': No such file or directory), что делать???? Вот программа #include "stdafx.h" #include<iostream> #include<conio.h> #include<cmath> using namespace std; int _tmain(int argc, _TCHAR* argv)
C++ Дана матрица: поэлементно вычесть первый столбец из всех столбцов, кроме первого Дана прямоугольная матрица В размером N × M. Составить программу, которая превратит матрицу следующим образом: поэлементно вычитает первый столбец из всех столбцов, кроме первого. http://www.cyberforum.ru/cpp-beginners/thread1108526.html
В прямоугольной матрицы часть элементов имеют нулевое значение. Заменить каждый нулевой элемент суммой смежных ему элементов (по горизонтали, вертикал C++
В прямоугольной матрицы часть элементов имеют нулевое значение. Заменить каждый нулевой элемент суммой смежных ему элементов (по горизонтали, вертикали и диагоналям). Формирование новой матрицы выполнять в буферном массиве.
Создание "карты" в двухмерном массиве C++
http://fast-pix.ru/i/f/2014-03-01/0-Karta.jpg Подскажите пожалуйста как можно создать "карту" в двухмерном массиве. Между "основными" городами еще есть "промежуточные" города. Суть: нужно для создания программы вывода маршрута с пункта А в пункт Б.
C++ Дано натуральное число,верно ли что http://www.cyberforum.ru/cpp-beginners/thread1108516.html
Дано натуральное число,верно ли, что произведение его цифр меньше а ,а само число делится на b? #include<conio.h>; #include<stdio.h>; #include<math.h>; int proizv( int x,int a, int b ) х -натур число ;и вот дальше я не знаю как написать условие,знаю,что нужен (for (счетчик = значение; счетчик < значение; шаг цикла) { тело цикла;} Не понимаю как начать и задать условие,сказали...
C++ оператор = и конструктор копирования Всем привет. Дана задача: создать класс книга с полями автор,название,год выпуска книги. С помощью односвязного списка создать класс каталог который включает в себя класс книга. Предусмотреть ф -ции добавления в каталог, поиск по каталогу, удаление из каталога(все эти ф-ции получились). Для себя решил сделать конструктор копирования и операцию присваивания но они работают неправильно. Помогите... подробнее

Показать сообщение отдельно
_include
Студент
 Аватар для _include
52 / 52 / 12
Регистрация: 17.09.2012
Сообщений: 291
Записей в блоге: 2
Завершенные тесты: 1
01.03.2014, 19:35     Поменять в матрице местами максимальный и минимальный элементы каждой строки
Суть: В строке находим максимум/минимум, запоминаем "координаты" этих данных, и меняем их местами.

Добавлено через 1 час 0 минут
Можно сделать например так:
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
#include "stdafx.h"
#include <math.h>
#include <conio.h>
#include <stdio.h>
#include <iostream>
#include <locale.h>
#include <ctime>
 
using namespace std;
 
const int  n = 3, m = 5;
 
void print(int massive[][m], int r)
{
    for(int i = 0; i < r; i++)
    {
        for (int j = 0; j < m; j++)
            {
                cout << "    " << massive[i][j];
            }
        cout << endl;
    }
}
 
void fun(int massive[][m], int r)
{
    int x = 0,y = 0;
    int min = 0, max = 0;
    for (int i = 0; i < r; i++)
    {      max = massive[0][0];min = massive[0][0];
            for (int j = 0; j < m; j++)
            {
                
                if(massive[i][j]>max)
                {
                    x = j;
                    max=massive[i][j];
                }
                if(massive[i][j]<min)
                {
                    y = j;
                    min=massive[i][j];
                }
            }
            massive[i][x] = min;
            massive[i][y] = max;
        }
    cout << "Sort mas:" << endl;
    print(massive,r);
}
void main()
{
    setlocale(LC_ALL, "Russian");
    int mas[n][m];
    srand(time(NULL));
    for(int i = 0; i < n; i++)
    {
        for(int j = 0; j < m; j++)
        {
            
            mas[i][j]=rand()%10-5;
        }
    }
    cout << "Local Mas:" << endl;
    print(mas,n);
    fun(mas,n);
    _getch();
}
Может довольно громоздко, но свою работу делает. Если в массиве есть одинаковые числа (-5 -5 или 2 2), то заменяется только первое.

Не по теме:

Я всегда люблю смотреть, что выводит программа. Ненужное можете выкинуть.
Всегда проверяйте правильность написания кода и всех переменных (например минут 20 пытался понять почему в программе больше строк чем нужно. Оказалось не ту переменную передаю)) ) Удачи!)

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