第五周作业——有向图邻接表表示及反向图构造

import java.io.*;  
import java.util.*;  
  
  
public class GraphReverse   
{  
    public static void main(String[] args)  
    {  
        try  
        {  
            FileReader fr=new FileReader("C:\\Users\SharpVoyage\DesktopttinyDG.txt");  
             BufferedReader br=new BufferedReader(fr);  
             int v,e;  
             String str="",str1="";  
             str=br.readLine();  
             v=Integer.parseInt(str);  
             System.out.println(v);  
             str="";  
             str=br.readLine();  
             e=Integer.parseInt(str);  
             System.out.println(e);  
             int a,b;  
  
             ll[] arr=new ll[v];  
             ll[] arr1=new ll[v];  
             for(a=0;a<v;a++)  
             {  
                 arr[a]=new ll();  
                 arr1[a]=new ll();  
             }  
               
             str="";  
             int t1;  
               
             while((t1=br.read())!=-1)  
             {  
                 str = str + (char) t1;   
                 if((char)t1==' ')  
                 {  
                     a = Integer.parseInt(str.trim());  
                     str="";  
                 }  
                       
                 if((char)t1=='\n')  
                 {  
                     b = Integer.parseInt(str.trim());   
                     arr[a].add(b);  
                     arr1[b].add(a);  
                     str="";  
                 }  
                       
             }  
               
             br.close();  
             fr.close();  
               
             FileOutputStream fos = new FileOutputStream("C:\\Users\\SharpVoyage\\Desktopt\\234.txt");    
             OutputStreamWriter osw = new OutputStreamWriter(fos, "gb2312");    
             BufferedWriter bw = new BufferedWriter(osw);   
               
             FileOutputStream fos1 = new FileOutputStream("C:\\Users\\SharpVoyage\\Desktopt\\345.txt");    
             OutputStreamWriter osw1 = new OutputStreamWriter(fos1, "gb2312");    
             BufferedWriter bw1 = new BufferedWriter(osw1);   
                
             for(a=0;a<v;a++)  
             {  
                 System.out.print(a+": ");  
                 for(b=0;b<arr[a].size();b++)  
                 {  
                     System.out.print(arr[a].get(b)+" ");  
                     str=str+Integer.toString(arr[a].get(b))+" ";  
                       
                 }  
                 System.out.println();  
                 str=Integer.toString(a)+": "+str;  
                  
                 bw.write(str);    
                 bw.newLine();  
                   
                 str="";   
                   
             }  
               
             System.out.println();  
             System.out.println();  
             str="";  
             for(a=0;a<v;a++)  
             {  
                 System.out.print(a+": ");  
                 for(b=0;b<arr1[a].size();b++)  
                 {  
                     System.out.print(arr1[a].get(b)+" ");  
                     str=str+Integer.toString(arr1[a].get(b))+" ";  
                       
                 }  
                 System.out.println();  
                 str=Integer.toString(a)+": "+str;  
                 bw1.write(str);    
                 bw1.newLine();   
                 str="";   
             }  
               
               
             bw.close();    
             osw.close();  
             bw1.close();    
             osw1.close();  
                   
        }  
        catch (NumberFormatException e)    
        {    
            e.printStackTrace();    
        }     
        catch (FileNotFoundException e)    
        {    
            e.printStackTrace();    
        }    
        catch (IOException e)    
        {    
            e.printStackTrace();    
        }    
    }  
      
       
}  
class ll  
{  
    private List list=new ArrayList();  
      
    public void add(int a)  
    {  
        list.add(a);  
    }  
    public int size()  
    {  
        return list.size();  
    }  
    public int get(int c)  
    {  
        return Integer.parseInt(list.get(c).toString());//object类型转为int  
    }  
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值