版權(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---員工管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---員工管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告---簡(jiǎn)單的職工管理系統(tǒng)
- 簡(jiǎn)單行編輯系統(tǒng)數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--員工信息管理系統(tǒng)
- 算法與數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)——員工管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)與算法課程設(shè)計(jì)-- 簡(jiǎn)單工資管理系統(tǒng)設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)-課程設(shè)計(jì)--學(xué)生管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--成績(jī)管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---成績(jī)管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)——簡(jiǎn)單行編輯程序
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--航班管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)—機(jī)場(chǎng)管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)----huffman編碼
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告--簡(jiǎn)單計(jì)算器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--圖書(shū)管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告--車(chē)庫(kù)管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--學(xué)生籍貫管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--圖書(shū)借閱管理系統(tǒng)
- 《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)---圖書(shū)管理系統(tǒng)
評(píng)論
0/150
提交評(píng)論