Портал аспирантов

Портал аспирантов (http://www.aspirantura.spb.ru/forum/index.php)
-   Физико-математические науки (http://www.aspirantura.spb.ru/forum/forumdisplay.php?f=128)
-   -   вопрос по динамическому массиву с++ (http://www.aspirantura.spb.ru/forum/showthread.php?t=13457)

Linka 24.02.2015 18:21

вопрос по динамическому массиву с++
 
Уважаемые форумчане! Очень стыдно спрашивать, но ситуация вынуждает. Под спойлером код на С++. Проблема следующая - динамический массив, который нужно заполнить) Массив заполняется, все хорошо. Но! я заполняю его дробными числами, а на выводе у меня в массиве целые числа (отсечена дробная часть чисел, которые я ввожу). Подскажите, пожалуйста, в чем проблема.
Скрытый текст
#include <iostream>
#include <iomanip>
#include <stdlib.h>

using namespace std;

int main()
{
int n = 0, m = 0;

// Ввод размерности массива
cout << "Введите число фаз и число пар данных n m" << endl;
cin >> n >> m;

// Выделение памяти под массив
double **vect;

try
{
vect = new double* [n];
} catch (bad_alloc ba)
{
cout << "cannot allocate mas in memory " << endl;
system("PAUSE");
exit(1);
}

for(int i = 0; i < n; ++i)
try
{
vect[i] = new double[m];
} catch (bad_alloc ba)
{
cout << "cannot allocate mas in memory" << endl;
system("PAUSE");
exit(1);
}


// Тут ввод массива
for (int i = 0; i < n; ++i)
{
for (int j = 0; j < m; ++j)
{
cout << "Заполните табличный элемент[" << i << "][" << j << "]: " ;
cin >> vect[i][j];
}

cout << endl;
}

for(int i = 0; i < n; ++i)
for(int j = 0; j < m; ++j)
{
int min = j;
for(int k = j; k < m; ++k)
{
if(vect[i][k] < vect[i][min])
min = k;
}

int c;
c = vect[i][j];
vect[i][j] = vect[i][min];
vect[i][min] = c;
}

//Вывод на экран
for (int i = 0; i < n; ++i)
{
for (int j = 0; j < m; ++j)
cout << setw (9) << vect[i][j] << " ";
cout << endl;
}

system("PAUSE");
return 0;

}

Bronepoezd 24.02.2015 18:47

Компилятора под рукой нет, но
int c;

пожалуй лучше заменить на
double c;

Ведь это переменная для обмена местами двух элементов вещественного массива. Так?

Можно ещ&#235; при выводе поставить
cout << fixed << то, что нужно напечатать ;

Да и в конце память, выделенную под массив, лучше освободить с помощью оператора delete.

Linka 24.02.2015 19:15

Bronepoezd, точно, помогло!!!!! спасибо огромное.

Добавлено через 5 минут
Цитата:

Сообщение от Bronepoezd (Сообщение 509938)
Да и в конце память, выделенную под массив, лучше освободить с помощью оператора delete.

а если мне этот массив нужен в последующих вычислениях?

Добавлено через 9 минут
а еще, если в двух словах, чем fixed отличается от setw ()? и так, и так работает хорошо

Alarmod 24.02.2015 20:01

Когда совсем-совсем не нужен, тогда и освобождайте.

Bronepoezd 24.02.2015 21:20

Цитата:

Сообщение от Linka (Сообщение 509940)
а если мне этот массив нужен в последующих вычислениях?

Цитата:

Сообщение от Alarmod (Сообщение 509944)
Когда совсем-совсем не нужен, тогда и освобождайте.

Согласен.

Цитата:

Сообщение от Linka (Сообщение 509940)
чем fixed отличается от setw ()

setw(n) -- выделяет n знаков для вывода числа. Если число занимает меньше знаков, то слева добавляются пробелы. Если больше -- число просто выводится полностью (два длинных числа при выводе подряд могут "склеиться", между ними может не быть пробелов, если их явно не поставить).

При печати вещественного числа по умолчанию выводится 6 знаков после запятой, если не ошибаюсь. Количество знаков регулируется с помощью cout.precision( n ) или setprecision( n ). При этом например 0.5 без fixed напечатается как 0.5, а с fixed как 0.500000. То есть fixed заставляет выводить ровно заданное количество знаков после запятой, не убирая нули в хвосте.

Linka 25.02.2015 07:56

Bronepoezd, спасибо Вам за такой оперативный ответ. Вы мне очень помогли. Я книжку еще не успела по программированию дочитать, а программа для работы понадобилась вот сейчас :)

Добавлено через 36 секунд
Alarmod, так и буду делать :)


Текущее время: 15:50. Часовой пояс GMT +3.

Powered by vBulletin® Version 3.8.8
Copyright ©2000 - 2024, vBulletin Solutions, Inc. Перевод: zCarot
© 2001—2024, «Аспирантура. Портал аспирантов»