-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathIs your horseshoe on the other hoof.cpp
107 lines (75 loc) · 2.53 KB
/
Is your horseshoe on the other hoof.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
/*Problem TWO
A. Is your horseshoe on the other hoof?
time limit per test2 seconds
memory limit per test256 megabytes
inputstandard input
outputstandard output
Valera the Horse is going to the party with friends. He has been following the fashion trends for a while, and he knows that it is very popular to wear all horseshoes of different color. Valera has got four horseshoes left from the last year, but maybe some of them have the same color. In this case he needs to go to the store and buy some few more horseshoes, not to lose face in front of his stylish comrades.
Fortunately, the store sells horseshoes of all colors under the sun and Valera has enough money to buy any four of them. However, in order to save the money, he would like to spend as little money as possible, so you need to help Valera and determine what is the minimum number of horseshoes he needs to buy to wear four horseshoes of different colors to a party.
Input
The first line contains four space-separated integers s1, s2, s3, s4 (1 ≤ s1, s2, s3, s4 ≤ 109) — the colors of horseshoes Valera has.
Consider all possible colors indexed with integers.
Output
Print a single integer — the minimum number of horseshoes Valera needs to buy.
PROBLEM LINL: https://codeforces.com/problemset/problem/228/A
*/
#include<bits/stdc++.h>
using namespace std;
int main() {
int s1,s2,s3,s4;
cin>>s1>>s2>>s3>>s4;
class Solution {
public:
void moveZeroes(vector<int>& nums) {
int n = nums.size();
int j= -1;
for(int i=0;i<n;i++){
if(nums[i]==0){
j=i;
break;
}
}
if(j!=-1){
for(int i=j+1;j<n-1;j++){
if(nums[i]!=0){
swap(nums[i],nums[j]);
j++;
}
}
}
}
};class Solution {
public:
void moveZeroes(vector<int>& nums) {
int n = nums.size();
int j= -1;
for(int i=0;i<n;i++){
if(nums[i]==0){
j=i;
break;
}
}
if(j!=-1){
for(int i=j+1;j<n-1;j++){
if(nums[i]!=0){
swap(nums[i],nums[j]);
j++;
}
}
}
}
};
vector<int> v;
v.push_back(s1);
v.push_back(s2);
v.push_back(s3);
v.push_back(s4);
sort(v.begin(), v.end());
int needstoBuy =0;
for(int i=1;i<v.size();i++) {
if(v[i]==v[i-1]){
needstoBuy++;
}
}
cout<<needstoBuy<<endl;
}