ユーザ定義のテストスコアを保持するのに十分な大きさのSTLベクトルを使用するプログラムを作成する必要があります。すべての数字が入力されたら、テストスコアを平均して昇順に並べ替える必要があります。私が持っている問題は、私が入れようとしているスコアの数を入れた後で、私が入れた数字の数字が何であっても、最初のものだけを読んでそれを平均として使い、昇順がかなりです私がお互い隣に置いた数の倍数。これは私がこれまで持っていたものです。何か助けてくれてありがとう!C++ STLベクトル
#include "stdafx.h"
#include <iostream>
#include <vector>
using namespace std;
float Average (vector<int> scores, int number);
void SortTestScores(vector<int> scores, int n);
void main(){
vector<int> testScores;
float averageScore, score;
int number, i;
cout << "Enter number of test scores: ";
cin >> number;
cout << "Enter test scores: ";
for (i = 0; i < number; i++){
cin >> score;
testScores.push_back(score);
}
SortTestScores(testScores, number);
cout << "Sorted test scores: ";
for (i = 0; i < number; i++){
cout << testScores.at(i);
}
averageScore = Average(testScores, number);
cout << "Average test score is: " << averageScore << endl;
system("pause");
}
//sort function
void SortTestScores(vector<int> scores, int number){
int temp; //temporary variable
int i, j; //loop variables
for (i = 1; i < number; i++){
for (j = 0; j < number - i; j++){
if (scores.at(j) > scores.at(j+1)){
temp = scores.at(j);
scores.at(j) = scores.at (j+1);
scores.at(j+1) = temp;
}
}
}
}
float Average(vector<int> score, int n){
int i;
float avg = 0.0;
for (i = 0; i < n; i++){
avg+=score.at(i);
}
avg = avg/n;
return avg;
}
'SortTestScores'が呼び出されると、ベクターのコピーを渡しています。メインのデータを変更したい場合は、ベクトルを参照する必要があります。 'Average'では効率化のためのコスト参照として渡すべきでしょう。 –