我遇到了插入排序功能的问题。虽然我试图使投票和名称按降序打印。投票似乎有效,但名称是按升序打印而不是降序。在我为名字插入b c d e f并为投票插入5 4 3 2 1之后,它看起来像这样:
Please input the canditate 1 name:
a
Please input the canditate 1 votes:
1
Please input the canditate 2 name:
b
Please input the canditate 2 votes:
2
Please input the canditate 3 name:
c
Please input the canditate 3 votes:
3
Please input the canditate 4 name:
d
Please input the canditate 4 votes:
4
Please input the canditate 5 name:
e
Please input the canditate 5 votes:
5
Candidate Votes Received % of Total Votes
a 5 33.33
b 4 26.67
c 3 20.00
d 2 13.33
e 1 6.67
Total 15
The winner of the elections is a.
Program ended with exit code: 0
Press any key to continue . . .
候选人需要是e b c a而不是b c d e 这是我的代码。任何帮助将不胜感激。
#include <iostream>
#include <string>
#include<iomanip>
using namespace std;
void insertionSort(double votes[], string name[], double len)
{
for (int i = 0; i < len - 1; i++)
{
int j = i + 1;
double temp = votes[j];
while (j > 0 && temp > votes[j - 1])
{
votes[j] = votes[j - 1];
j--;
votes[j] = temp;
}
string temp2 = name[j];
while (j > 0 && temp2 > name[j - 1])
{
name[j] = name[j - 1];
j--;
name[j] = temp2;
}
}
}
int main()
{
//Declaring variables
string *name;
double *votes;
double *percentage;
double total = 0;
int max = 0;
name = new string[5];
votes = new double[5];
percentage = new double[5];
//for condition for user to input Canditate names and the votes received
for (int i = 0; i < 5; i++)
{
cout << "Please input the canditate " << i + 1 << " " << "name: " << endl;
cin >> name[i];
cout << "Please input the canditate " << i + 1 << " " << "votes: " << endl;
cin >> votes[i];
total = total + votes[i];
}
//Q1 or Q2
//selectionSort(votes, name, 5);
insertionSort(votes, name, 5);
//printing out the Canditate, voters received, and % of total votes
cout << "Candidate" << "\t\t" << "Votes Received" << "\t\t" << "% of Total Votes" << endl;
//for loop in order to find % of total votes, winner of election
for (int i = 0; i < 5; i++)
{
if (votes[i]>votes[max])
max = i;
cout << name[i] << "\t\t\t" << fixed << setprecision(0) << votes[i] << "\t\t\t" << fixed << setprecision(2) << (votes[i] * 100 / total) << endl;
}
//printing out the total and winner of the election
cout << "Total" << "\t\t\t" << fixed << setprecision(0) << total << endl;
cout << "The winner of the elections is " << name[max] << "." << endl;
delete[]name;
delete[]votes;
cout << "Program ended with exit code: 0" << endl;
return 0;
}
答案 0 :(得分:1)
你需要使数据一致,即在结构中保持一致,尝试:
#include <iostream>
#include <string>
#include<iomanip>
using namespace std;
/*void selectionSort(double votes[], string name[], double len)
{
for (int i = 0; i < len-1; i++)
{
double max = (int)i;
for (int j = i+1; j < len; j++)
{
if (votes[j]>votes[(int)max])
{
double temp = votes[i];
votes[i] = votes[j];
votes[j] = temp;
string temp2 = name[i];
name[i] = name[j];
name[j] = temp2;
}
}
}
}*/
struct candidate{
string *name;
double votes;
double percentage;
};
void insertionSort( candidate candidates[], double len)
{
for (int i = 0; i < len - 1; i++)
{
int j = i + 1;
candidate tmp = candidates[i];
while (j > 0 && tmp.votes > candidates[j-1].votes)
{
candidates[j] = candidates[j - 1];
j--;
candidates[j] = tmp;
}
}
}
int main()
{
//Declaring variables
candidate candidates[5];
double total = 0;
int max = 0;
//for condition for user to input Canditate names and the votes received
for (int i = 0; i < 5; i++)
{
candidates[i].name = new string;
cout << "Please input the canditate " << i + 1 << " " << "name: " << endl;
cin >> *(candidates[i].name);
cout << "Please input the canditate " << i + 1 << " " << "votes: " << endl;
cin >> candidates[i].votes;
total = total + candidates[i].votes;
}
//Q1 or Q2
//selectionSort(candidates, 5);
insertionSort(candidates, 5);
//printing out the Canditate, voters received, and % of total votes
cout << "Candidate" << "\t\t" << "Votes Received" << "\t\t" << "% of Total Votes" << endl;
//for loop in order to find % of total votes, winner of election
for (int i = 0; i < 5; i++)
{
cout << *(candidates[i].name) << "\t\t\t" << fixed << setprecision(0) << candidates[i].votes << "\t\t\t" << fixed << setprecision(2) << (candidates[i].votes * 100 / total) << endl;
}
//printing out the total and winner of the election
cout << "Total" << "\t\t\t" << fixed << setprecision(0) << total << endl;
cout << "The winner of the elections is " << *(candidates[0].name) << "." << endl;
for(int i=0; i<5; ++i)
delete candidates[i].name;
cout << "Program ended with exit code: 0" << endl;
return 0;
}