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

В матрицах Р (7х8) и Q (8х6) поменять местами первую строку и строчку, в которой находится первый нулевой элемент - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Метод наискорейшего спуска для СЛАУ/метод сопряжённых градиентов для СЛАУ http://www.cyberforum.ru/cpp-beginners/thread687341.html
Помогите, пожалуйста, найти реализацию вышеперечисленных методов. На С++, но если будет Си, Паскаль или Ява - буду тоже премного благодарен. PS Достаточно одного из них.
C++ Неправильный ввод for(i=0;i<n;i++) { std::cin>>temp; if(!std::cin) { std::cin.clear(); while(std::cin.get()!='\n') continue; std::cout<<"ERROR.\n"; break; http://www.cyberforum.ru/cpp-beginners/thread687336.html
C++ Соритровка слиянием
Всем доброго времени суток! В универе задали задачку на сортировку списка слиянием, в теории я всё понял, только не понял как это реализовать, может кто подскажет как отсортировать список? Мне нужен только алгоритм самой сортировки на c++, создание списка и прочее не нужно. Может у кого завалялся исходничек? Заранее спасибо
Как массив перебирать с конца? C++
Простой цикл for(i=0;i<n;i++) начинает перебирать массив с первого элемента по последний а как записать чтобы цикл начал перебирать с останьго элемента и до первого?
C++ Лямбды http://www.cyberforum.ru/cpp-beginners/thread687303.html
Непонятно, как работает это простенький код, и почему именно так: int id = 0; auto f = () mutable { cout << "id: " << id << std::endl; ++id; }; id = 42; f(); f(); f();
C++ Массив: Найти сумму элементов массива, расположенных между первым и последним отрицательными элементами. Помогите, пожалуйста. Как решить в с++. Дан целочисленный массив размера N. Найти сумму элементов массива, расположенных между первым и последним отрицательными элементами. Размер массива N задается в виде константы в исходном коде программы. Все числа вводятся с клавиатуры. подробнее

Показать сообщение отдельно
Leshak
259 / 235 / 40
Регистрация: 10.12.2011
Сообщений: 513
05.11.2012, 23:44
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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
// lamp.cpp : Defines the entry point for the console application.
//
 
#include "stdafx.h"
#include <ctime>
#include <iostream>
#include <conio.h>
#include <iomanip>
#include <locale.h>
 
using namespace std;
void main( )
{
    setlocale(LC_ALL,"Rus");
    int P[7][8], Q[8][6], i, j, temp, index_p = 1, index_q = 1;
    /* Заполнение матриц случайными элементами */
    /* --------------- */
    srand((unsigned)time(NULL));
    for (int i=0; i<7 ; i++)
    {
     for (int j=0; j<8 ; j++)
        P[i][j]=3-rand()%14;
    }
    /* --------------- */
    for (int i=0; i<8 ; i++)
    {
     for (int j=0; j<6 ; j++)
        Q[i][j]=3-rand()%14;
    }
    /* --------------- */
    /* Вывод матриц */
    cout<<"Матрица Р (7х8):\n";
    for (int i=0; i<7 ; i++ )
    {
        for (int j=0; j<8 ; j++)
        cout<<setw(3)<<P[i][j];
        cout<<endl;
    }
    cout<<"\n";
    cout<<"Матрица Q (8х6):\n";
    for (int i=0; i<8 ; i++ )
    {
        for (int j=0; j<6 ; j++)
        cout<<setw(3)<<Q[i][j];
        cout<<endl;
    }
    cout<<"\n";
    /* --------------- */
    /* Поиск первого нуля( не учитывая первой строки ) */
    for (int i=1; i<7 ; i++)
    {
      for (int j=0; j<8 ; j++)
      
            if ( P[i][j] == 0 ) 
                index_p = i ; 
                 break;
      
    }       
    /* --------------- */
    /* Меняем первую строку со строкой в которой мы нашли первый ноль */
    for (int i=0; i<7 ; i++ ){
         temp = P[index_p][i];
         P[index_p][i] = P[0][i];        
         P[0][i] = temp;
    }
    /* Вывод матрицы */
    cout<<"Матрица Р (7х8) c изменением:\n";
    for (int i=0; i<7 ; i++ )
    {
        for (int j=0; j<8 ; j++)
        cout<<setw(3)<<P[i][j];
        cout<<endl;
    }
    /* --------------- */
    /* Повторяем действия для второго массива */
    for (int i=1; i<8 ; i++)
    {
      for (int j=0; j<6 ; j++)
      
            if ( Q[i][j] == 0 ) 
                index_q= i ; 
                 break;
      
    }
    /* --------------- */
    for (int i=0; i<8 ; i++ ){
         temp = Q[index_q][i];
         Q[index_q][i] = Q[0][i];        
         Q[0][i] = temp;
    }
    /* --------------- */
    cout<<"Матрица Q (8х6) c изменением:\n";
    for (int i=0; i<8 ; i++ )
    {
        for (int j=0; j<6 ; j++)
        cout<<setw(3)<<Q[i][j];
        cout<<endl;
    }
    _getch();
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru