度度熊想去商场买一顶帽子,商场里有N顶帽子,有些帽子的价格可能相同。度度熊想买一顶价格第三便宜的帽子,问第三便宜的帽子价格是多少?
输入描述:
首先输入一个正整数N(N <= 50),接下来输入N个数表示每顶帽子的价格(价格均是正整数,且小于等于1000
输出描述:
如果存在第三便宜的帽子,请输出这个价格是多少,否则输出-1
示例1
输入
10
10 10 10 10 20 20 30 30 40 40
输出
30
我的方案:
set方法:
#include<iostream>
#include<set>
#include<string>
#include<algorithm>
using namespace std;
int main()
{
cout << "请输入帽子总数";
int count;
cin >> count;
cout << endl;
cout << "请分别输入帽子价格:" << endl;
set<int> s;
while (count--)
{
int i;
cin >> i;
s.insert(i);
}
set<int>::iterator ite1 = s.begin();
set<int>::iterator ite2 = s.end();
for (; ite1 != ite2; ite1++)
{
cout << *ite1;
}
cout << endl;
if (s.size() < 3)
cout << "没有第三便宜帽子";
else
{
set<int>::iterator ite3 = s.begin();
ite3++;
ite3++;
cout << "第三便宜帽子价格为:" <<*ite3 << endl;
}
return 0;
}
vector方法:
//输入描述:首先输入一个正整数N,N<=50,接下来输入N个数表示每顶帽子的价格
//输出描述:如果存在第三便宜的帽子,请输出这个价格是多少,否则输入-1
#include<iostream>
#include<vector>
#include<string>
#include<algorithm>
using namespace std;
int main20()
{
cout << "请输入帽子总数";
int count;
cin >> count;
cout << endl;
cout << "请分别输入帽子价格:"<<endl;
vector<int> v;
int i=0;
while (count--)
{
cin >> i;
v.push_back(i);
}
cout <<"输入完毕" << endl;
sort(v.begin(), v.end());
v.erase(unique(v.begin(), v.end()), v.end());//删去一个元素边上与它相同的元素
cout << "dfdf" << endl;
for (int i = 0; i < v.size(); i++)
{
cout << v[i] << " ";
}
if (v.size() < 3)
cout << "没有第三便宜帽子";
else
cout << "第三便宜帽子价格为:" << v[2] << endl;
system("pause");
return 0;
}
网友们的方法:
//set方法
#include <iostream>
#include <set>
int main(void)
{
int n;
while(std::cin >> n)
{
std::set<int> iprice_N;
for(int i=0; i<n; ++i)
{
int ivalue;
std::cin >> ivalue;
iprice_N.insert(ivalue);
}
if(iprice_N.size() < 3)
{
std::cout << -1 << std::endl;
continue;
}
//set里面是元素是不允许重复的,并且自动从小到大排序好了
std::set<int>::iterator it = iprice_N.begin();
it++;
it++;
std::cout << *it << std::endl;
}
return 0;
}
//数组方法
#include<iostream>
#include<algorithm>
using namespace std;
int main() {
int n;
int prize[50];
cin >> n;
if(n<3) {
cout<<"-1";
return 0;
}
for (int i = 0; i < n; i++) {
cin >> prize[i];
}
sort(prize, prize + n);
int cnt = 0;
for (int i = 0; i < n; i++) {
if (prize[i + 1] > prize[i]&&(i+1)<n) {
cnt++;
if (cnt == 2) {
cout << prize[i + 1];
}
}
}
if(cnt<2) {
cout<<"-1";
return 0;
}
return 0;
}
//vector方法
#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
int main(){
int n,tmp;
cin>>n;
vector<int> v;
while(n--){
cin>>tmp;
v.push_back(tmp);
}
sort(v.begin(),v.end());
v.erase(unique(v.begin(),v.end()),v.end());
cout<<(v.size()<3?-1:v[2]);
return 0;
}
参考自:http://s3.nowcoder.com/questionTerminal/f3aaf8fedcea43c6b12a11710068726b?toCommentId=527216
https://blog.csdn.net/qq_41937767/article/details/80510130
https://blog.csdn.net/u011361880/article/details/77480377?utm_source=blogxgwz9