Вывод Результата
В этом заключительном шаге вы улучшите программу векторных операций, добавив форматированный вывод и создав функцию для вывода результатов векторов в ясном и удобочитаемом формате.
Обновите файл vector_operations.c следующим улучшенным кодом:
cd ~/project
nano vector_operations.c
Добавьте новую функцию вывода и измените главную программу:
#include <stdio.h>
#define VECTOR_SIZE 3
void readVector(float vector[], int size) {
printf("Введите %d компоненты вектора (через пробел): ", size);
for (int i = 0; i < size; i++) {
scanf("%f", &vector[i]);
}
}
float computeDotProduct(float vector1[], float vector2[], int size) {
float dotProduct = 0.0;
for (int i = 0; i < size; i++) {
dotProduct += vector1[i] * vector2[i];
}
return dotProduct;
}
void computeCrossProduct(float vector1[], float vector2[], float result[]) {
result[0] = vector1[1] * vector2[2] - vector1[2] * vector2[1];
result[1] = vector1[2] * vector2[0] - vector1[0] * vector2[2];
result[2] = vector1[0] * vector2[1] - vector1[1] * vector2[0];
}
// Новая функция для вывода вектора с форматированием
void printVector(const char* label, float vector[], int size) {
printf("%s: [", label);
for (int i = 0; i < size; i++) {
printf("%.2f%s", vector[i], (i < size - 1) ? ", " : "");
}
printf("]\n");
}
int main() {
float vector1[VECTOR_SIZE];
float vector2[VECTOR_SIZE];
float crossProductResult[VECTOR_SIZE];
// Ввод векторов
printf("Ввод векторов:\n");
printVector("Вектор 1", vector1, VECTOR_SIZE);
readVector(vector1, VECTOR_SIZE);
printVector("Вектор 2", vector2, VECTOR_SIZE);
readVector(vector2, VECTOR_SIZE);
// Вычисление результатов
float dotProduct = computeDotProduct(vector1, vector2, VECTOR_SIZE);
computeCrossProduct(vector1, vector2, crossProductResult);
// Вывод форматированных результатов
printf("\nРезультаты операций с векторами:\n");
printVector("Вектор 1", vector1, VECTOR_SIZE);
printVector("Вектор 2", vector2, VECTOR_SIZE);
printf("Скалярное произведение: %.2f\n", dotProduct);
printVector("Векторное произведение", crossProductResult, VECTOR_SIZE);
return 0;
}
Компилируем и запускаем обновлённую программу:
gcc vector_operations.c -o vector_operations
./vector_operations
Пример вывода:
Ввод векторов:
Вектор 1: [0.00, 0.00, 0.00]
Введите 3 компоненты вектора (через пробел): 1 2 3
Вектор 2: [0.00, 0.00, 0.00]
Введите 3 компоненты вектора (через пробел): 4 5 6
Результаты операций с векторами:
Вектор 1: [1.00, 2.00, 3.00]
Вектор 2: [4.00, 5.00, 6.00]
Скалярное произведение: 32.00
Векторное произведение: [-3.00, 6.00, -3.00]
Объяснение
- Добавлена функция
printVector() для создания согласованного и форматированного вывода векторов.
- Улучшена функция
main() для демонстрации ввода векторов и вывода результатов.
- Улучшена читаемость векторов и результатов вычислений.
- Предоставлен чистый и профессиональный формат вывода для операций с векторами.