Solução OBI 2018 Cinco
Enunciado
Podemos criar um algoritmo guloso simples, trocar sempre (em ordem):
- O dígito mais significativo que for trocado por um número maior do que ele
- (na falha do primeiro) O dígito menos significativo que for trocado por um número menor do que ele
#include <bits/stdc++.h>
using namespace std;
int main() {
int n;
scanf("%d",&n);
int arr[n];
for(int i=0;i<n;i++) scanf("%d",&arr[i]);
for(int i=0;i<n;i++) {
if(arr[i]<arr[n-1]&&(arr[i]==0||arr[i]==5)) {
swap(arr[i],arr[n-1]);
for(int j=0;j<n;j++) printf("%d%c",arr[j],j==n-1?'\n':' ');
exit(0);
}
}
for(int i=n-1;i>=0;i--) {
if(arr[i]==0||arr[i]==5) {
swap(arr[i],arr[n-1]);
for(int j=0;j<n;j++) printf("%d%c",arr[j],j==n-1?'\n':' ');
exit(0);
}
}
puts("-1");
return 0;
}