數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--簡(jiǎn)單的員工管理系統(tǒng)_第1頁(yè)
已閱讀1頁(yè),還剩18頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、<p>  數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告</p><p>  班 級(jí):____軟件121_____________</p><p>  姓 名:___________________</p><p>  指導(dǎo)教師:__________________</p><p>  成 績(jī):________________________

2、__</p><p><b>  信息工程學(xué)院</b></p><p>  2014 年 1 月 9 日</p><p><b>  題目1 </b></p><p><b>  1.需求分析</b></p><p><b>  

3、簡(jiǎn)單的員工管理系統(tǒng)</b></p><p>  每一個(gè)員工的信息包括:編號(hào)、姓名、性別、出生年月、學(xué)歷、職務(wù)、電話、住址等,系統(tǒng)的功能包括:</p><p> ?。?)查詢:按特定條件查找員工。</p><p> ?。?)修改:按編號(hào)對(duì)某個(gè)員工的某項(xiàng)信息進(jìn)行修改</p><p>  (3)排序:按特定條件對(duì)所有員工的信息進(jìn)行排序&

4、lt;/p><p>  (4)插入:按編號(hào)刪除已離職的員工的信息。</p><p>  (5)刪除:按編號(hào)刪除已離職的員工信息。</p><p><b>  2.概要設(shè)計(jì)</b></p><p>  java.io.Serializable // 實(shí)現(xiàn)可比較和序列化接口</p><p>  publ

5、ic Friend(String name, String code)//構(gòu)造方法</p><p>  public int compareTo(Friend f)//比較兩個(gè)對(duì)象大小,實(shí)現(xiàn)Comparable接口</p><p>  public Object[] toArray() //將對(duì)象的兩個(gè)成員變量保存在對(duì)象數(shù)組中</p><p>  public St

6、affManagementSystem(String filename) //構(gòu)造圖形用戶界面</p><p>  public StaffManagementSystem()//員工管理系統(tǒng)</p><p>  private void readFromFile() //從指定文件中讀取已有對(duì)象</p><p>  private void getFamilyN

7、ame() //JList添加其中所有姓氏</p><p>  public void valueChanged(ListSelectionEvent e)//列表框的選擇事件處理方法</p><p>  public void actionPerformed(ActionEvent e) //單擊事件處理方法</p><p>  public void

8、 windowClosing(WindowEvent e)//關(guān)閉窗口事件處理方法</p><p><b>  詳細(xì)設(shè)計(jì)</b></p><p>  //Friend.java</p><p>  public class Friend implements java.lang.Comparable<Friend>, java.io

9、.Serializable // 實(shí)現(xiàn)可比較和序列化接口</p><p><b>  {</b></p><p>  private String name; //姓名</p><p>  private String code; //編號(hào)</p><p>  pu

10、blic Friend(String name, String code)//構(gòu)造方法</p><p><b>  {</b></p><p>  this.name = name;</p><p>  this.code = code;</p><p><b>  }</b></p>

11、<p>  public String getName() //獲得姓名</p><p><b>  {</b></p><p>  return this.name;</p><p><b>  }</b></p><p>  public String getcode() /

12、/獲得電話號(hào)碼</p><p><b>  {</b></p><p>  return this.code;</p><p><b>  }</b></p><p>  public String toString() </p><p><b>  {</b

13、></p><p>  return "("+this.name+", "+this.code+")";</p><p><b>  }</b></p><p>  public int compareTo(Friend f)//比較兩個(gè)對(duì)象大小,實(shí)現(xiàn)Comparable接口&l

14、t;/p><p>  { //指定排序次序</p><p>  if (!this.name.equals(f.name)) </p><p>  return this.name.compareTo(f.name); //兩人以姓名為序</p><p><b>  else<

15、/b></p><p>  return this.code.compareTo(f.code); //同一人以電話號(hào)碼為序</p><p><b>  }</b></p><p>  public Object[] toArray() //將對(duì)象的兩個(gè)成員變量保存在對(duì)象數(shù)組中</p><p><b>

16、  {</b></p><p>  Object[] vars = new Object[2];</p><p>  vars[0] = this.name;</p><p>  vars[1] = this.code;</p><p>  return vars;</p><p><b>  }

17、</b></p><p><b>  }</b></p><p>  //StaffManagementSystem.java</p><p>  import java.util.*;</p><p>  import java.awt.*;</p><p>  import jav

18、a.awt.event.*;</p><p>  import javax.swing.*;</p><p>  import javax.swing.event.*;</p><p>  import javax.swing.table.*;</p><p>  import java.io.*;</p><p> 

19、 public class StaffManagementSystem extends JFrame implements ListSelectionListener, ActionListener, WindowListener</p><p><b>  {</b></p><p>  private String filename; //文件名<

20、/p><p>  private TreeSet<Friend> tbook; //使用一個(gè)樹(shù)集合存儲(chǔ)多個(gè)Friend對(duì)象</p><p>  private JList list; //列表框</p><p>  private DefaultListModel listModel; //默認(rèn)列表框模型</

21、p><p>  private JTable table; //表格組件</p><p>  private DefaultTableModel tableModel; //默認(rèn)表格模型</p><p>  private JComboBox combobox_name; //姓名組合框</p><

22、;p>  private DefaultComboBoxModel comboModel; //組合框模型,選擇姓氏</p><p>  private JTextField text_code; //編號(hào)文本行</p><p>  public StaffManagementSystem(String filename) //構(gòu)造圖形用戶界面</p>&l

23、t;p><b>  {</b></p><p>  super("員工管理系統(tǒng)");</p><p>  this.setBounds(300,300,450,300);</p><p>  this.setDefaultCloseOperation(EXIT_ON_CLOSE);</p><p&g

24、t;  this.addWindowListener(this);//注冊(cè)窗口事件監(jiān)聽(tīng)器</p><p>  JSplitPane split_h=new JSplitPane(JSplitPane.HORIZONTAL_SPLIT); </p><p><b>  //水平分割窗格</b></p><p>  split_h.setDivid

25、erLocation(40); //設(shè)置垂直分隔條的位置</p><p>  this.getContentPane().add(split_h);</p><p>  //初始化一個(gè)容器,在容器上添加字符串組(無(wú)該語(yǔ)句則白屏)</p><p>  JSplitPane split_v=new JSplitPane(JSplitPane.VERTICAL_SPLIT

26、); </p><p><b>  //垂直分割窗格</b></p><p>  split_v.setDividerLocation(180); //設(shè)置水平分隔條的位置</p><p>  this.filename = filename;</p><p>  tbook = new TreeSet<Frie

27、nd>();</p><p>  this.readFromFile(); //從指定文件中讀取已有對(duì)象信息</p><p>  this.listModel = new DefaultListModel(); //默認(rèn)列表框模型</p><p>  this.listModel.addElement("姓氏&quo

28、t;); </p><p>  this.list = new JList(listModel); //創(chuàng)建列表框</p><p>  this.list.setSelectionMode(ListSelectionModel.SINGLE_SELECTION); //設(shè)置單選模式,默認(rèn)為多選</p><p>  this.list.addList

29、SelectionListener(this); //列表框注冊(cè)選擇事件監(jiān)聽(tīng)器</p><p>  split_h.add(new JScrollPane(this.list)); //添加在滾動(dòng)窗格中</p><p>  split_h.add(split_v);</p><p>  String[] columns={"姓名","

30、編號(hào)","性別","誕日","學(xué)歷","職務(wù)","電話","住址"}; //表格各列的中文標(biāo)題</p><p>  this.tableModel=new DefaultTableModel(columns,0); </p><p>

31、;  //默認(rèn)表格模型,指定列標(biāo)題,0行</p><p>  this.table=new JTable(tableModel); //創(chuàng)建空表格,有列標(biāo)題</p><p>  this.list.setSelectedIndex(0);//選中列表框第一項(xiàng),執(zhí)行valueChanged()方法</p><p>  split_v.add(new JScrollP

32、ane(table));</p><p>  //以下面板包括組合框、文本行和添加、刪除、查找等按鈕</p><p>  JPanel friendpanel=new JPanel(new GridLayout(2,1)); </p><p>  //將下框的內(nèi)容分成2行1列</p><p>  split_v.add(friendpanel

33、);</p><p>  JPanel panels[]={new JPanel(), new JPanel()};</p><p>  for (int i=0; i<panels.length; i++)</p><p>  friendpanel.add(panels[i]);</p><p>  panels[0].add(ne

34、w JLabel(columns[0]));</p><p>  this.comboModel = new DefaultComboBoxModel(); //默認(rèn)組合框模型</p><p>  combobox_name = new JComboBox(this.comboModel); </p><p>  combobox_name.setEditable(

35、true);</p><p>  panels[0].add(combobox_name);</p><p>  panels[0].add(new JLabel(columns[1]));</p><p>  this.text_code = new JTextField("1", 12);//編號(hào)長(zhǎng)度</p><p>

36、  panels[0].add(text_code);</p><p>  this.getFamilyName(); //列表框和組合框添加其中所有姓氏 </p><p>  String buttonstr[]={"添加","刪除","按編號(hào)查找"};</p><p>  JButton but

37、tons[] = new JButton[buttonstr.length];</p><p>  for (int i=0; i<buttons.length; i++)</p><p><b>  {</b></p><p>  buttons[i] = new JButton(buttonstr[i]);</p>&l

38、t;p>  panels[1].add(buttons[i]);</p><p>  buttons[i].addActionListener(this);</p><p><b>  }</b></p><p>  this.setVisible(true);</p><p><b>  }</b

39、></p><p>  public StaffManagementSystem()</p><p><b>  {</b></p><p>  this("friends.dat"); //指定默認(rèn)文件名</p><p><b>  }</b></p>&

40、lt;p>  private void readFromFile() //從指定文件中讀取已有對(duì)象</p><p><b>  {</b></p><p><b>  try</b></p><p><b>  {</b></p><p>  FileInputStrea

41、m fin=new FileInputStream(this.filename); //文件字節(jié)輸入流</p><p>  ObjectInputStream objin=new ObjectInputStream(fin);//對(duì)象字節(jié)輸入流</p><p>  while (true) //輸入流未結(jié)束時(shí)</p><p><

42、b>  try</b></p><p><b>  {</b></p><p>  tbook.add((Friend)objin.readObject()); //讀取一個(gè)對(duì)象添加到系統(tǒng)</p><p><b>  }</b></p><p>  catch (Exception

43、 e)//捕獲ClassNotFoundException和EOFException異常 </p><p><b>  {</b></p><p><b>  break;</b></p><p><b>  }</b></p><p>  objin.close();

44、//先關(guān)閉對(duì)象流</p><p>  fin.close(); //再關(guān)閉文件流</p><p><b>  }</b></p><p>  catch (IOException ioe){} //指定文件不存在時(shí),表格為空</p><p><b>  }</b></p>&l

45、t;p>  private void getFamilyName() //JList添加其中所有姓氏</p><p><b>  {</b></p><p>  if (!tbook.isEmpty())</p><p><b>  {</b></p><p>  Iterator it=

46、tbook.iterator(); //返回一個(gè)迭代器對(duì)象</p><p>  while (it.hasNext()) //若有后繼元素,使用迭代器遍歷集合</p><p><b>  {</b></p><p>  Friend f=(Friend)it.next(); //返回后繼元素</p><p&

47、gt;  String familyname=f.getName().charAt(0)+"";//獲得姓氏</p><p>  if (!this.listModel.contains(familyname))</p><p><b>  {</b></p><p>  this.listModel.addElement(

48、familyname); //列表框模型添加不重復(fù)數(shù)據(jù)項(xiàng)</p><p>  this.comboModel.addElement(familyname); //組合框模型添加不重復(fù)數(shù)據(jù)項(xiàng)</p><p><b>  }</b></p><p><b>  }</b></p><p><b&g

49、t;  }</b></p><p><b>  } </b></p><p>  public void valueChanged(ListSelectionEvent e)//列表框的選擇事件處理方法</p><p><b>  {</b></p><p>  String famil

50、yname=(String)list.getSelectedValue();</p><p>  //返回列表框選中數(shù)據(jù)項(xiàng)對(duì)象</p><p>  if (!tbook.isEmpty() && familyname!=null && familyname!="")</p><p>  //以選中姓氏更新表格<

51、;/p><p><b>  {</b></p><p>  for (int i=this.tableModel.getRowCount()-1; i>=0; i--)//清空表格</p><p>  this.tableModel.removeRow(i); </p><p>  Itera

52、tor it = tbook.iterator();</p><p>  while (it.hasNext()) //在系統(tǒng)中查找指定姓氏</p><p><b>  {</b></p><p>  Friend f = (Friend)it.next();</p><p>  if (familyname==&qu

53、ot;姓氏" || f.getName().charAt(0)==familyname.charAt(0))</p><p>  this.tableModel.addRow(f.toArray()); //表格添加一行,參數(shù)數(shù)組指定各列值</p><p><b>  }</b></p><p><b>  }</

54、b></p><p><b>  }</b></p><p>  public void actionPerformed(ActionEvent e) //單擊事件處理方法</p><p><b>  {</b></p><p>  if (e.getActionCommand().e

55、quals("添加")) //單擊添加按鈕</p><p><b>  {</b></p><p>  String name=(String)combobox_name.getSelectedItem();</p><p>  String code=text_code.getText();</p><

56、;p>  Friend f = new Friend(name, code);</p><p>  if (!name.equals("") && !tbook.contains(f)) </p><p>  //不能插入姓名空串和重復(fù)對(duì)象</p><p><b>  {</b></p>

57、<p>  tbook.add(f);//添加對(duì)象,TreeSet不插入重復(fù)元素,沒(méi)提示也不拋出異常</p><p>  String familyname = name.charAt(0)+"";//返回姓名的第一個(gè)字符</p><p>  if (list.getSelectedValue().equals(familyname))</p>

58、<p>  tableModel.addRow(f.toArray()); </p><p><b>  else</b></p><p><b>  {</b></p><p>  if (!listModel.contains(familyname)) //列表框中添加不重復(fù)元素</p&

59、gt;<p><b>  {</b></p><p>  listModel.addElement(familyname);</p><p>  comboModel.addElement(familyname);</p><p><b>  }</b></p><p>  list.

60、setSelectedValue(familyname,true);//設(shè)置列表框選中項(xiàng)</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  else</b></p><p>  JOptionPane.showMessa

61、geDialog(this, "不能添加姓名空串或重復(fù)對(duì)象"+f.toString());</p><p><b>  }</b></p><p>  if (e.getActionCommand().equals("刪除"))</p><p><b>  {</b></p&g

62、t;<p>  if (tbook.isEmpty())</p><p>  JOptionPane.showMessageDialog(this, "表格空,不能刪除數(shù)據(jù)項(xiàng)。");</p><p><b>  else</b></p><p><b>  {</b></p>

63、<p>  int i = table.getSelectedRow(); //表格當(dāng)前選中行號(hào)</p><p>  if (i==-1)</p><p>  JOptionPane.showMessageDialog(this, "請(qǐng)選擇數(shù)據(jù)項(xiàng)。");</p><p><b>  else</b></

64、p><p><b>  {</b></p><p>  String name=(String)table.getValueAt(i,0);</p><p>  int yes=JOptionPane.showConfirmDialog(null, "刪除\""+name+"\"行?");

65、</p><p>  //確認(rèn)對(duì)話框包括Yes和No按鈕</p><p>  if (yes==0) //單擊確認(rèn)對(duì)話框的Yes按鈕</p><p><b>  {</b></p><p>  String code=(String)table.getValueAt(i,1);</p><p>

66、  tbook.remove(new Friend(name, code)); //刪除對(duì)象</p><p>  tableModel.removeRow(i);//表格中刪除一行</p><p>  listModel.removeElement(name.charAt(0)+"");//列表框中刪除指定姓氏 </p><p>  comboM

67、odel.removeElement(name.charAt(0)+"");</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b>

68、</p><p>  if (!tbook.isEmpty() && e.getActionCommand().equals("按編號(hào)查找"))</p><p>  { //查找編號(hào),結(jié)果顯示在表格中</p><p>  Friend find = null;</p><

69、p>  Iterator it = tbook.iterator();</p><p>  while (find==null && it.hasNext())</p><p><b>  {</b></p><p>  Friend f = (Friend)it.next();</p><p> 

70、 if (f.getcode().equals(text_code.getText()))//比較編號(hào)字符串</p><p><b>  find = f;</b></p><p><b>  }</b></p><p>  if (find!=null) //若查找成功</p><p>

71、;<b>  {</b></p><p>  for (int i=tableModel.getRowCount()-1; i>=0; i--) //清空表格</p><p>  this.tableModel.removeRow(i); </p><p>  this.tableModel.addR

72、ow(find.toArray()); </p><p><b>  }</b></p><p>  else JOptionPane.showMessageDialog(this, "未查找到滿足條件的數(shù)據(jù)!");</p><p><b>  }</b></p><p>&l

73、t;b>  }</b></p><p>  public void windowClosing(WindowEvent e)//關(guān)閉窗口事件處理方法</p><p><b>  {</b></p><p>  try //將其中所有對(duì)象寫(xiě)入指定文件</p><p>  

74、{ //指定文件不存在時(shí),表格為空創(chuàng)建新文件</p><p>  FileOutputStream fout=new FileOutputStream(this.filename); </p><p><b>  //文件字節(jié)輸出流</b></p><p>  ObjectOutputStream objout=new Objec

75、tOutputStream(fout); </p><p><b>  //對(duì)象字節(jié)輸出流</b></p><p>  if (!tbook.isEmpty())</p><p><b>  {</b></p><p>  Iterator it = tbook.iterator();</p

76、><p>  while (it.hasNext())</p><p>  objout.writeObject((Friend)it.next()); //寫(xiě)入一個(gè)對(duì)象</p><p><b>  }</b></p><p>  objout.close();</p><p>  fout.clo

77、se();</p><p><b>  }</b></p><p>  catch (IOException ioe){}</p><p><b>  }</b></p><p>  public void windowOpened(WindowEvent e) {}</p><

78、p>  public void windowActivated(WindowEvent e) {}</p><p>  public void windowDeactivated(WindowEvent e) {}</p><p>  public void windowClosed(WindowEvent e) {}</p><p>  public voi

79、d windowIconified(WindowEvent e) {}</p><p>  public void windowDeiconified(WindowEvent e) {}</p><p>  public static void main(String args[])</p><p><b>  {</b></p>

80、<p>  new StaffManagementSystem(); //默認(rèn)文件名為"frindes.dat"</p><p><b>  } </b></p><p><b>  } </b></p><p><b>  4.調(diào)試分析</b><

81、/p><p> ?。?)調(diào)試過(guò)程中問(wèn)題:主要是一些框架結(jié)構(gòu)的定義以及一些語(yǔ)法上的應(yīng)用,通過(guò)查找API可以詳細(xì)知道其意思,并應(yīng)用到程序中。</p><p><b>  (2)需要的改進(jìn):</b></p><p>  A、實(shí)現(xiàn)檢查電話號(hào)碼的位數(shù)。</p><p>  B、增加員工管理系統(tǒng)的修改功能。</p><

82、;p>  C、雙擊表格一列,能夠修改,響應(yīng)事件保存修改內(nèi)容。</p><p>  (3)經(jīng)驗(yàn)和體會(huì):這次編寫(xiě)的代碼主要是修改別人的代碼,在這個(gè)過(guò)程中雖然沒(méi)有完全做到自己編寫(xiě),但是也認(rèn)真看了,說(shuō)實(shí)話很多都不怎么懂,感覺(jué)好多要記憶的東西,比如一些框架的定義,操作動(dòng)作的語(yǔ)法定義。經(jīng)過(guò)這幾天的練習(xí),表示在編程方面還是要花上很多心思和時(shí)間的。</p><p><b>  5.測(cè)試結(jié)果

83、</b></p><p><b>  題目2</b></p><p><b>  1.需求分析</b></p><p><b>  求圖的最短路徑問(wèn)題</b></p><p><b>  概要設(shè)計(jì)</b></p><p>

84、;  typedef struct{ }MGraph; //定義鄰接矩陣結(jié)構(gòu)體</p><p>  void ShortestPath_DIJ(MGraph G,int v0,PathMatrix &P,ShortPathTable &D) //說(shuō)明最短路徑結(jié)構(gòu)</p><p>  int LocateVex(MGraph G,char u) //定位鄰接矩陣各個(gè)頂點(diǎn)是否有

85、誤</p><p>  void CreateMGraph(MGraph &G) //建立鄰接矩陣</p><p><b>  3.詳細(xì)設(shè)計(jì)</b></p><p>  #include <stdio.h> </p><p>  #include <stdlib.h> </p>

86、<p>  #define INT_MAX 2147483647 </p><p>  #define INFINITY INT_MAX </p><p>  #define FALSE 0 </p><p>  #define TRUE 1</p><p>  #define NumVertices 6 //圖中最大頂點(diǎn)個(gè)數(shù)

87、</p><p>  typedef int PathMatrix[NumVertices][NumVertices]; //最短路徑數(shù)組 </p><p>  typedef int ShortPathTable[NumVertices]; //最短路徑長(zhǎng)度 </p><p>  typedef int AdjMatrix[NumVertices][NumVert

88、ices]; </p><p>  typedef char VertexType; </p><p>  typedef struct{ </p><p>  VertexType vexs[NumVertices]; </p><p>  AdjMatrix arcs; //鄰接矩陣 </p><p>  int

89、vexnum,arcnum; </p><p><b>  }MGraph; </b></p><p>  int LocateVex(MGraph G,char u); </p><p>  void CreateMGraph(MGraph &G); </p><p>  void ShortestPath_D

90、IJ(MGraph G,int v0,PathMatrix &P,ShortPathTable &D); </p><p>  int main() </p><p><b>  { </b></p><p><b>  int v0;</b></p><p><b> 

91、 char u;</b></p><p>  MGraph G; </p><p>  PathMatrix P; </p><p>  ShortPathTable D; </p><p>  printf("最短路徑!\n"); </p><p>  CreateMGraph(G);

92、 </p><p>  printf("Input Source :"); </p><p>  fflush(stdin); </p><p>  scanf("%c",&u);</p><p>  v0=LocateVex(G,u);</p><p>  Shorte

93、stPath_DIJ(G,v0,P,D);</p><p><b>  return 0;</b></p><p><b>  } </b></p><p>  void ShortestPath_DIJ(MGraph G,int v0,PathMatrix &P,ShortPathTable &D) &l

94、t;/p><p><b>  { </b></p><p>  int final[NumVertices]; </p><p><b>  int w,v; </b></p><p><b>  //step1 </b></p><p>  for (v=

95、0;v<G.vexnum;++v) </p><p><b>  { </b></p><p>  final[v]=FALSE; //final[v]為FALSE即未求得v0到V的最短路徑 </p><p>  D[v]=G.arcs[v0][v]; //D[v]為帶權(quán)長(zhǎng)度 </p><p>  for ( w=

96、0;w<G.vexnum;++w) </p><p>  P[v][w]=FALSE; //若P[v][w]為FALSE,則w不是從v0到v當(dāng)前求的最短路徑上的頂點(diǎn) </p><p>  if (D[v]<INFINITY) //D[v]為帶權(quán)長(zhǎng)度</p><p><b>  { </b></p><p> 

97、 P[v][v0]=TRUE; </p><p>  P[v][v]=TRUE; </p><p><b>  } </b></p><p><b>  } </b></p><p>  for (int i=1;i<G.vexnum;++i)//step4 </p><p

98、>  { //step2 </p><p>  int min = INFINITY; </p><p>  for (w=0;w<G.vexnum ;++w) </p><p>  if (!final[w]) //!final[w] 表示V-S </p><p>  if (D[w]<min) </p>&

99、lt;p><b>  {</b></p><p><b>  v=w;</b></p><p><b>  min=D[w];</b></p><p><b>  } </b></p><p>  final[v]=TRUE; //final[v]為

100、TRUE當(dāng)且僅當(dāng)V∈V-S,即已經(jīng)求得v0到V的最短路徑 </p><p><b>  //step3 </b></p><p>  for (w=0;w<G.vexnum;++w) </p><p>  if(G.arcs[v][w]!=INFINITY)</p><p>  if (!final[w]&

101、&(min+G.arcs[v][w]<D[w])) </p><p><b>  { </b></p><p>  D[w]=min+G.arcs[v][w]; </p><p>  for (int j=0;j<G.vexnum;++j) </p><p>  P[w][j]=P[v][j]; &l

102、t;/p><p>  P[w][w]=TRUE; </p><p><b>  } </b></p><p><b>  } </b></p><p>  printf("------------------------------------------------------\n&q

103、uot;);</p><p>  printf(" 始點(diǎn) 終點(diǎn) 路徑長(zhǎng)度 \n");</p><p>  printf("------------------------------------------------------\n");</p><p>  printf("

104、 %c ",G.vexs[v0]); </p><p>  for(w=0;w<G.vexnum;++w)</p><p><b>  {</b></p><p><b>  if(w!=0)</b></p><p>  printf(" ");<

105、/p><p><b>  if(w==v0)</b></p><p>  printf(" %c \n",G.vexs[w]); </p><p><b>  else</b></p><p>  if(D[w]==INFINITY)<

106、;/p><p><b>  {</b></p><p>  printf(" %c ",G.vexs[w]); </p><p>  printf("無(wú)\n"); </p><p><b>  }</b></p>

107、<p><b>  else</b></p><p>  printf(" %c %d\n",G.vexs[w],D[w]); </p><p><b>  }</b></p><p>  printf("-----------------

108、-------------------------------------\n");</p><p><b>  } </b></p><p>  int LocateVex(MGraph G,char u) </p><p><b>  { </b></p><p><b> 

109、 int i; </b></p><p>  for (i=0;i<G.vexnum;i++) </p><p>  if (u == G.vexs[i]) </p><p>  return i; </p><p>  if (i == G.vexnum) </p><p><b>  {

110、 </b></p><p>  printf("Error u!\n"); </p><p><b>  exit(1); </b></p><p><b>  } </b></p><p>  return 0; </p><p><b

111、>  } </b></p><p>  void CreateMGraph(MGraph &G) //建立鄰接矩陣 </p><p><b>  { </b></p><p>  int i,j,k,w; </p><p>  char v1,v2; </p><p> 

112、 G.vexnum=6;</p><p>  G.arcnum=10;</p><p>  for (i=0;i<G.vexnum;i++) </p><p>  G.vexs[i]='0'+i;</p><p>  for (i=0;i<G.vexnum;i++) </p><p>  f

113、or (j=0;j<G.vexnum;j++) </p><p>  G.arcs[i][j]=INFINITY;</p><p>  G.arcs[0][2]=10;</p><p>  G.arcs[0][4]=30;</p><p>  G.arcs[0][5]=100;</p><p>  G.arcs[

114、1][2]=5;</p><p>  G.arcs[2][3]=50;</p><p>  G.arcs[3][5]=10;</p><p>  G.arcs[4][3]=20;</p><p>  G.arcs[4][5]=60;</p><p>  for (i=0;i<G.vexnum;i++) </

115、p><p>  for(j=0;j<G.vexnum;j++)</p><p><b>  {</b></p><p>  if(G.arcs[i][j]!=INFINITY)</p><p>  printf("%4d",G.arcs[i][j]);</p><p><

116、;b>  else</b></p><p>  printf("%4d",0);</p><p>  if(j%G.vexnum==G.vexnum-1)</p><p>  printf("\n");</p><p><b>  }</b></p>

117、<p><b>  return; </b></p><p><b>  }</b></p><p><b>  調(diào)試分析</b></p><p><b>  調(diào)試過(guò)程中問(wèn)題:</b></p><p>  不會(huì)就百度看看別人怎么解釋的,<

118、/p><p><b>  需要的改進(jìn):</b></p><p>  A、實(shí)現(xiàn)復(fù)雜的圖的最短路徑,不僅僅限于自己編寫(xiě)出的鄰接矩陣表</p><p>  B、實(shí)現(xiàn)從鍵盤(pán)輸入各個(gè)邊的起點(diǎn)終點(diǎn)及權(quán)值</p><p>  經(jīng)驗(yàn)和體會(huì):多去編寫(xiě)程序,熟悉一些語(yǔ)句的語(yǔ)法結(jié)構(gòu)及如何應(yīng)用,而不是僅僅限于從顯示器表達(dá)題目意思</p>

119、<p><b>  測(cè)試結(jié)果</b></p><p><b>  6.參考文獻(xiàn)</b></p><p>  (1).Java程序設(shè)計(jì)常用教程</p><p>  (2).數(shù)據(jù)結(jié)構(gòu)(C語(yǔ)言版)</p><p><b>  (3).C程序設(shè)計(jì)</b></p>

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論