#include<iostream>
using namespace std;
struct huan{
int node;
bool isfound;
int start;
};
int min(int a,int b){
int temp;
if(a>b){
temp=a;
a=b;
b=temp;
//cout<<"a="<<a<<endl;
}
return a;
}
int main(){
int node_number; //节点总数
int vector_number; //边的总数
int **store; //用来存储结点m前的节点
int rest[50]={0}; //用来存储每个节点前还剩余多少个节点
int j[50]={0}; //初始化数据均为零
int start_node; //输入的边的两端顶点
int end_node;
int result[50];
int m=0;
huan hu[51][51];
int hresult[50]={-1};
int h[50]={0};
cin>>node_number;
cin>>vector_number;
store=new int*[node_number];
for(int i=0;i<node_number;i++){
store[i]=new int[node_number];
} //创建动态二维数组
for(int i=0;i<node_number;i++){
for(int j=0;j<node_number;j++){
store[i][j]=-1;
}
}
for(int i=0;i<50;i++){
for(int j=0;j<50;j++){
hu[i][j].isfound=0;
hu[i][j].node=-1;
}
}
for(int i=0;i<vector_number;i++){
cin>>start_node;
cin>>end_node;
store[end_node-1][j[end_node-1]]=start_node-1;//
j[end_node-1]++;
rest[end_node-1]++;
hu[start_node-1][h[start_node]].node=end_node-1; //error
h[start_node]++;
}
int v;
for(int i=0;i<node_number;i++){
for(int j=0;j<node_number;j++){
if(rest[j]==0){
rest[j]=-1; //rest[j]==0,说明该节点前已经不存在节点,result=-1,说明该节点已经存储到result数组中
result[m]=j+1;
m=m+1;
//cout<<result[m-1]<<endl;
for(int p=0;p<node_number;p++){
for(int q=0;q<node_number;q++){
if(store[p][q]==j){
store[p][q]=store[p][rest[p]-1];
store[p][rest[p]-1]=-1;
rest[p]--;
}
//for(int t=0;t<node_number;t++){
//store[p][t]=-1;
//}
//rest[p]=0;
}
}
break;
}
}
}
bool p=0;
for(int i=0;i<node_number;i++){
if(rest[i]!=-1){
p=1;
}
}
if(p==0){
cout<<"YES"<<endl;
for(int i=0;i<m;i++){
cout<<result[i]<<",";
}
}
if(p==1){
cout<<"NO"<<endl;
for(int i=0;i<node_number;i++){
hu[i][50].start=50; //将hu的数组最后一个初始化为-1;
}
for(int i=0;i<node_number;i++){
for(int j=0;j<node_number;j++){
if(hu[i][j].node!=-1){
if(hu[i][50].start==50){
hu[i][50].start=i;
}
hu[hu[i][j].node][50].start=min(hu[hu[i][j].node][50].start,hu[i][50].start);
hu[i][j].start=hu[i][50].start;
}
}
}
int hr=0;
int templ;
bool b=0;
for(int i=0;i<node_number;i++){
for(int j=0;j<node_number;j++){
if(hu[i][j].node==hu[i][50].start&&hresult[hr]==-1){
hresult[hr]=hu[i][50].start;
hr++;
templ=i;
while(templ!=hu[i][50].start){
for(int p=0;p<node_number;p++){
for(int q=0;q<node_number;q++){
if(hu[p][q].node==templ&&hu[p][q].start==hu[i][50].start){
b=1;
//cout<<"templ"<<templ<<endl;
templ=p;
//f=hu[p][q].node;
hresult[hr]=hu[p][q].node;
hr++;
break;
}
}
if(b==1){
b=0;
break;
}
}
}
hresult[hr]=templ;
break;
}
}
if(b==1){
b=0;
break;
}
}
for(int i=hr;i>=0;i--){
cout<<hresult[i]+1<<",";
}
}
}