← Home
#include <bits/stdc++.h>
using namespace std;
int n,m,num;
int f[100004],c[100004],ans=1e9;
vector<int>g[100004];
bool vis[100004];
void dfs(int x){
	vis[x]=1;num++;
	for(auto y:g[x])if(!vis[y])dfs(y);
}
void b(int x,int t){
	for(int i=n;i>=x;i--)f[i]=min(f[i-x]+t,f[i]);
}
void bfsearch(int x){
	if(x>n)return;
	ans=min(ans,f[x]);
	bfsearch(x*10+4),bfsearch(x*10+7);
}
int main(){
	scanf("%d%d",&n,&m);
	for(int i=1;i<=m;i++){
		int u,v;scanf("%d%d",&u,&v);
		g[u].push_back(v),g[v].push_back(u);
	}
	for(int i=1;i<=n;i++)f[i]=1e9;
	for(int i=1;i<=n;i++)if(!vis[i]){
		num=0;dfs(i);
		c[num]++;
	}
	for(int i=1;i<=n;i++)if(c[i]){
		for(int j=1;j<=c[i];c[i]-=j,j<<=1)b(j*i,j);
		if(c[i])b(c[i]*i,c[i]);
	}
	bfsearch(4),bfsearch(7);
	if(ans==1e9)puts("-1");
	else printf("%d",ans-1);
}