#include <iostream>

using namespace std;

int n, m;
int susedi[101][101];
int boje[101];

bool moze_boja(int cvor, int boja)
{
    for (int predajnik = 0; predajnik < n; predajnik++)
        if (susedi[predajnik][cvor] and boje[predajnik] == boja)
            return false;
    return true;
}

bool resi(int cvor)
{
    if (cvor == n)
        return true;
    for (int boja = 1; boja <= 3; boja++)
    {
        if (moze_boja(cvor, boja))
        {
            boje[cvor] = boja;
            if (resi(cvor + 1))
                return true;
            boje[cvor] = 0;
        }
    }
    return false;
}

int main()
{
    cin >> n >> m;
    for (int i = 0; i < n; i++)
    {
        boje[i] = 0;
        for (int j = 0; j < m; j++)
            susedi[i][j] = false;
    }
    for (int i = 0; i < m; i++)
    {
        int od_prijemnika, ka_prijemniku;
        cin >> od_prijemnika >> ka_prijemniku;
        susedi[od_prijemnika][ka_prijemniku] = true;
        susedi[ka_prijemniku][od_prijemnika] = true;
    }
    if (resi(0))
    {
        for (int i = 0; i < n; i++)
            cout << boje[i] << " ";
        cout << endl;
    }
    else
        cout << "-" << endl;
    return 0;
}