hdu 5055 Bob and math problem (很简单贪心)

给N个数字(0-9),让你组成一个数。

要求:1.这个数是奇数    2.这个数没有前导0

问这个数最大是多少。

 

思路&解法:

N个数字从大到小排序,将最小的奇数与最后一位交换,把剩下前N-1位从大到小排序。输出。(判断第一位是否为0)

 

代码:

#include <cstdio>
#include <iostream>
#include <string.h>
#include <cstdlib>
#include <algorithm>
#include <queue>
#include <vector>
#include <cmath>
#include <map>
#include <stack>
using namespace std;
int const uu[4] = {1,-1,0,0};
int const vv[4] = {0,0,1,-1};
typedef long long ll;
int const maxn = 50005;
int const inf = 0x3f3f3f3f;
ll const INF = 0x7fffffffffffffffll;
double eps = 1e-10;
double pi = acos(-1.0);
#define rep(i,s,n) for(int i=(s);i<=(n);++i)
#define rep2(i,s,n) for(int i=(s);i>=(n);--i)
#define mem(v,n) memset(v,(n),sizeof(v))
#define lson l, m, rt<<1
#define rson m+1, r, rt<<1|1

int n;
int a[105];

bool cmp(int a,int b){
    return a>b;
}
int main(){
    while(scanf("%d",&n)!=EOF){
        rep(i,0,n-1) scanf("%d",&a[i]);
        sort(a,a+n,cmp);

        int t1=-1;
        rep2(i,n-1,0) if(a[i]%2==1){
            t1=i;
            break;
        }
        if(t1==-1){
            printf("-1\n");
            continue;
        }
        swap(a[t1],a[n-1]);
        sort(a,a+n-1,cmp);
        if(a[0]==0){
            printf("-1\n");
            continue;
        }
        rep(i,0,n-1) printf("%d",a[i]); cout<<endl;
    }
}

 

posted @ 2014-09-29 19:58  fish7  阅读(198)  评论(0编辑  收藏  举报