#include <bits/stdc++.h>
using namespace std;
ifstream fin("ctc.in");
ofstream fout("ctc.out");
int n, m;
vector<int> g[100001], gt[100001], afis[100001];
int vizitat[100001], cnt = 0;
stack<int> st;
void dfs(int x) {
vizitat[x] = 1;
for(auto i : g[x]) {
if(!vizitat[i]) {
dfs(i);
}
}
st.push(x);
}
void dfs2(int x) {
vizitat[x] = 2;
afis[cnt].push_back(x);
for(auto i : gt[x]) {
if(vizitat[i] == 1)
{
dfs2(i);
}
}
}
int main(){
fin >> n >> m;
for(int i = 1; i <= m; i++) {
int a, b;
fin >> a >> b;
g[a].push_back(b);
gt[b].push_back(a);
}
for(int i = 1; i <= n; i++) {
if(!vizitat[i]) {
dfs(i);
}
}
while(!st.empty()) {
int acuma = st.top();
st.pop();
if(vizitat[acuma] == 1) {
cnt++;
dfs2(acuma);
}
}
fout << cnt << '\n';
for(int i = 1; i <= cnt; i++) {
for(auto j : afis[i]) {
fout << j << " ";
}
fout << '\n';
}
}