数据结构课程设计报告交通灯问题.doc

上传人:laozhun 文档编号:3944445 上传时间:2023-03-28 格式:DOC 页数:15 大小:70KB
返回 下载 相关 举报
数据结构课程设计报告交通灯问题.doc_第1页
第1页 / 共15页
数据结构课程设计报告交通灯问题.doc_第2页
第2页 / 共15页
数据结构课程设计报告交通灯问题.doc_第3页
第3页 / 共15页
数据结构课程设计报告交通灯问题.doc_第4页
第4页 / 共15页
数据结构课程设计报告交通灯问题.doc_第5页
第5页 / 共15页
点击查看更多>>
资源描述

《数据结构课程设计报告交通灯问题.doc》由会员分享,可在线阅读,更多相关《数据结构课程设计报告交通灯问题.doc(15页珍藏版)》请在三一办公上搜索。

1、数据结构课程设计课题28:交通灯问题多叉路口交通灯的管理问题。通常,在十字交叉路口只需设红、绿两色的交通灯便可保持正常的交通秩 序,而在多叉路口需设几种颜色的交通灯才能既使车辆相互之间不 碰撞,又能达到车辆的最大流通。假设有一个如图(a)所示的五叉路口,其中C和E为单行道。在路口有13条可行的通路,其中有的 可以同时通行,如AB和EC,而有的不能同时通行,如EB和AD。那么,在路口应如何设置交通灯进行车辆的管理呢?求解步骤:1.模型表示:(1)由于题目要求是对多叉路口交通灯的管理。一般,在十字交叉路口我们只需设红、绿两色的交通灯便可保持正常的交通秩序,但是在多叉路口需设多种颜色的交通灯才能既使

2、车辆相互之间不碰撞,又能达到车辆的最大流通。题目给出如上图(a)所示的五叉路口,其中C和E为单行道。在路口有13条可行的通路,其中有的可以同时通行,如AB 和EC,而有的不能同时通行,如EB 和AD。要求出在路口应如何设置交通灯进行车辆的管理。(2)在图中,用箭头表示一条通路,如下图,B.A.E.D路口的红绿点表示交通灯,按交通规则,红灯停,绿灯行。某交通路口的绿灯亮了,则此路口的车可开出,其他路口的车可开进,求解是假设C路口无交通灯,而且B处灯为绿灯,其它为红灯,按此模型可以求解后可以让各个路口的车辆正常通行。2.算法设计:设计本题算法的构思如下:为求出符合条件的交通灯数,要在求解过程中进行

3、试探,按照图形依据交通规则让交通灯在十秒内改变,所以程序编写时箭头试探可行路径,若试探成功,会在试探完毕后图形将显示此时的所有可行路径,即此时的箭头指向。设置如下:(1)JTD.cpp定义应用程序的入口点。在JTD.cpp中定义全局变量:HINSTANCE hIn表示当前实例;TCHAR szTitleMAX_LOADSTRING表示标题栏文本;TCHAR szWindowClassMAX_LOADSTRING表示主窗口类名。函数: MyRegisterClass()目的是注册窗口类。函数: InitInstance(HINSTANCE, int)目的是保存实例句柄并创建主窗口,在此函数中,我

4、们在全局变量中保存实例句柄并创建和显示主程序窗口。函数: WndProc(HWND, UINT, WPARAM, LPARAM)目的是处理主窗口的消息WM_COMMAND 处理应用程序菜单WM_PAINT- 绘制主窗口WM_DESTROY- 发送退出消息并返回INT_PTR CALLBACK About(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam) “关于”框的消息处理函数。(2)op.cpp定义应用程序。程序定义可以存储五个路口一维数组g_LK5;函数initdata(HWND hWnd)对数据进行初始化;在应用程序中作图时调用

5、JTD.cpp中的函数实现消息的响应,则会在窗口的客户区画出所求图形,在画图时的探索过程中即已实现算法的描述,求解出题目所要实现的交通灯管理,需四种颜色的交通灯才能使车辆正常通行。3.程序实现:为上机实现本题,还需要做一些工作:1.添加功能:由算法可知,需要添加一些功能,如输入数据建图、输出路径,显示求解状态等。2.结构及类型说明:若采用数据结构实验工具,则可借助于实验工具中的存储结构,因此可省掉诸如类型说明、建图、显示图等许多麻烦。于是我采用win32应用程序中的典型的“helloword”程序,它可以提供并自动生成一些程序代码,在其中实现图形的显示更容易。3.输入图结构:为方便地调试算法,

6、需要能方便地建图。若采用逐个输入元素的方式来建图,会比较麻烦,这对调试算法来说也是不方便的。为此,在“JTD.CPP”中利用一些函数实现消息响应,在程序实现时,调用这些函数即可实现图形中箭头的表示。4.显示结构:合理地显示结构是调试算法所必需的。在此,采用工具系统中的图结构、数组等有关功能,以方便地显示结构。5.显示输出结果:输出结果也必须要以可接受的形式显示出来。此处为形象的表达出图形以便观察,当一个交通灯亮时,用箭头表示此时可以通行的路口的车。完整程序如下:#pragma once#include resource.hextern void DrawLk(HDC hdc,HWND hWnd

7、);extern void DrawSec(HDC hdc);extern void initdata(HWND hWnd);/ JTD.cpp : 定义应用程序的入口点。/#include stdafx.h#include JTD.h#define MAX_LOADSTRING 100/ 全局变量:HINSTANCE hInst;/ 当前实例TCHAR szTitleMAX_LOADSTRING;/ 标题栏文本TCHAR szWindowClassMAX_LOADSTRING;/ 主窗口类名/ 此代码模块中包含的函数的前向声明:ATOMMyRegisterClass(HINSTANCE hI

8、nstance);BOOLInitInstance(HINSTANCE, int);LRESULT CALLBACKWndProc(HWND, UINT, WPARAM, LPARAM);INT_PTR CALLBACKAbout(HWND, UINT, WPARAM, LPARAM);int APIENTRY _tWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPTSTR lpCmdLine, int nCmdShow)UNREFERENCED_PARAMETER(hPrevInstance);UNREFERENCED_PARAM

9、ETER(lpCmdLine); / TODO: 在此放置代码。MSG msg;HACCEL hAccelTable;/ 初始化全局字符串LoadString(hInstance, IDS_APP_TITLE, szTitle, MAX_LOADSTRING);LoadString(hInstance, IDC_JTD, szWindowClass, MAX_LOADSTRING);MyRegisterClass(hInstance);/ 执行应用程序初始化:if (!InitInstance (hInstance, nCmdShow)return FALSE;hAccelTable = Lo

10、adAccelerators(hInstance, MAKEINTRESOURCE(IDC_JTD);/ 主消息循环:while (GetMessage(&msg, NULL, 0, 0)if (!TranslateAccelerator(msg.hwnd, hAccelTable, &msg)TranslateMessage(&msg);DispatchMessage(&msg);return (int) msg.wParam;/ 函数: MyRegisterClass()/ 目的: 注册窗口类。/ 注释:/ 仅当希望/ 此代码与添加到 Windows 95 中的“RegisterClass

11、Ex”/ 函数之前的 Win32 系统兼容时,才需要此函数及其用法。调用此函数十分重要,/ 这样应用程序就可以获得关联的/ “格式正确的”小图标。/ATOM MyRegisterClass(HINSTANCE hInstance)WNDCLASSEX wcex;wcex.cbSize = sizeof(WNDCLASSEX);wcex.style= CS_HREDRAW | CS_VREDRAW;wcex.lpfnWndProc= WndProc;wcex.cbClsExtra= 0;wcex.cbWndExtra= 0;wcex.hInstance= hInstance;wcex.hIcon

12、= LoadIcon(hInstance, MAKEINTRESOURCE(IDI_JTD);wcex.hCursor= LoadCursor(NULL, IDC_ARROW);wcex.hbrBackground= (HBRUSH)(COLOR_WINDOW+1);wcex.lpszMenuName= MAKEINTRESOURCE(IDC_JTD);wcex.lpszClassName= szWindowClass;wcex.hIconSm= LoadIcon(wcex.hInstance, MAKEINTRESOURCE(IDI_SMALL);return RegisterClassEx

13、(&wcex);/ 函数: InitInstance(HINSTANCE, int)/ 目的: 保存实例句柄并创建主窗口/ 注释:/ 在此函数中,我们在全局变量中保存实例句柄并/ 创建和显示主程序窗口。/extern int nSt;extern int nSec;BOOL InitInstance(HINSTANCE hInstance, int nCmdShow) HWND hWnd; hInst = hInstance; / 将实例句柄存储在全局变量中 hWnd = CreateWindow(szWindowClass, szTitle, WS_OVERLAPPEDWINDOW, CW_

14、USEDEFAULT, 0, CW_USEDEFAULT, 0, NULL, NULL, hInstance, NULL); if (!hWnd) return FALSE; ShowWindow(hWnd, nCmdShow); UpdateWindow(hWnd); return TRUE;/ 函数: WndProc(HWND, UINT, WPARAM, LPARAM)/ 目的: 处理主窗口的消息。/ WM_COMMAND- 处理应用程序菜单/ WM_PAINT- 绘制主窗口/ WM_DESTROY- 发送退出消息并返回/LRESULT CALLBACK WndProc(HWND hWn

15、d, UINT message, WPARAM wParam, LPARAM lParam)int wmId, wmEvent;PAINTSTRUCT ps;HDC hdc;switch (message)case WM_COMMAND:wmId = LOWORD(wParam);wmEvent = HIWORD(wParam);/ 分析菜单选择:switch (wmId)case IDM_ABOUT:DialogBox(hInst, MAKEINTRESOURCE(IDD_ABOUTBOX), hWnd, About);break;case IDM_EXIT:DestroyWindow(hW

16、nd);break;default:return DefWindowProc(hWnd, message, wParam, lParam);break;case WM_CREATE:initdata(hWnd);SetTimer(hWnd,0,1000,NULL);break;case WM_PAINT:hdc = BeginPaint(hWnd, &ps);/ TODO: 在此添加任意绘图代码.DrawLk(hdc,hWnd);EndPaint(hWnd, &ps);break;case WM_TIMER: nSec-; DrawSec(GetDC(hWnd); if(nSec4)nSt=1

17、;InvalidateRect(hWnd,NULL,TRUE); break;case WM_DESTROY:PostQuitMessage(0);break;default:return DefWindowProc(hWnd, message, wParam, lParam);return 0;/ “关于”框的消息处理程序。INT_PTR CALLBACK About(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)UNREFERENCED_PARAMETER(lParam);switch (message)case WM_INIT

18、DIALOG:return (INT_PTR)TRUE;case WM_COMMAND:if (LOWORD(wParam) = IDOK | LOWORD(wParam) = IDCANCEL)EndDialog(hDlg, LOWORD(wParam);return (INT_PTR)TRUE;break;return (INT_PTR)FALSE;struct LKchar name10;/路口名POINT P;POINT P1;POINT P2;POINT P3;POINT P4; char b;/b=0双向,1单向char c;/c=0只出,c=1只入POINT PT4;#inclu

19、de stdafx.h#include stdio.h#include op.h#include #include LK g_LK5;POINT org;double R=0;double W;int nSec=10;int nSt=1;void initdata(HWND hWnd)RECT rect;int kr;POINT tmp;double pi = 3.1415926535;GetClientRect(hWnd,&rect);if(rect.right-rect.left)(rect.bottom-rect.top)kr=rect.bottom-rect.top;else kr=r

20、ect.right-rect.left;R=(kr-40)/2;org.x=(rect.right-rect.left)/2-R;org.y=(rect.bottom-rect.top)/2-R;strcpy(g_LK0.name,A);W=R/5;g_LK0.b=0;g_LK0.c=0;g_LK0.P.x=org.x+R;g_LK0.P.y=org.y;g_LK0.P1.x=g_LK0.P.x-W;g_LK0.P1.y=g_LK0.P.y;g_LK0.P2.x=g_LK0.P.x+W;g_LK0.P2.y=g_LK0.P.y;g_LK0.P3.x=g_LK0.P1.x;g_LK0.P3.y=

21、g_LK0.P1.y+2*W;g_LK0.P4.x=g_LK0.P2.x;g_LK0.P4.y=g_LK0.P2.y+2*W;g_LK1.b=0;g_LK1.c=0;g_LK1.P.x=org.x+R*(1-sin(pi*2/5);g_LK1.P.y=org.y+R*(1-cos(pi*2/5);g_LK1.P1.x=g_LK1.P.x+W*cos(pi*2/5);g_LK1.P1.y=g_LK1.P.y-W*sin(pi*2/5);g_LK1.P2.x=g_LK1.P.x-W*cos(pi*2/5);g_LK1.P2.y=g_LK1.P.y+W*sin(pi*2/5);g_LK1.P3.x=

22、g_LK1.P.x+2*W*sin(pi*2/5)+W*cos(pi*2/5);g_LK1.P3.y=g_LK1.P.y+2*W*cos(pi*2/5)-W*sin(pi*2/5);g_LK1.P4.x=g_LK1.P.x+2*W*sin(pi*2/5)-W*cos(pi*2/5);g_LK1.P4.y=g_LK1.P.y+2*W*cos(pi*2/5)+W*sin(pi*2/5);g_LK2.b=0;g_LK2.c=0;g_LK2.P.x=org.x+R*(1-sin(pi/5);g_LK2.P.y=org.y+R*(1+cos(pi/5);g_LK2.P1.x=g_LK2.P.x-W*co

23、s(pi/5);g_LK2.P1.y=g_LK2.P.y-W*sin(pi/5);g_LK2.P2.x=g_LK2.P.x+W*cos(pi/5);g_LK2.P2.y=g_LK2.P.y+W*sin(pi/5);g_LK2.P3.x=g_LK2.P.x+2*W*sin(pi/5)-W*cos(pi/5);g_LK2.P3.y=g_LK2.P.y-2*W*cos(pi/5)-W*sin(pi/5);g_LK2.P4.x=g_LK2.P.x+2*W*sin(pi/5)+W*cos(pi/5);g_LK2.P4.y=g_LK2.P.y-2*W*cos(pi/5)+W*sin(pi/5);g_LK3

24、.b=0;g_LK3.c=0;g_LK3.P.x=2*org.x+2*R-g_LK2.P.x;g_LK3.P.y=g_LK2.P.y;g_LK3.P1.x=2*org.x+2*R-g_LK2.P2.x;g_LK3.P1.y=g_LK2.P2.y;g_LK3.P2.x=2*org.x+2*R-g_LK2.P1.x;g_LK3.P2.y=g_LK2.P1.y;g_LK3.P3.x=2*org.x+2*R-g_LK2.P4.x;g_LK3.P3.y=g_LK2.P4.y;g_LK3.P4.x=2*org.x+2*R-g_LK2.P3.x;g_LK3.P4.y=g_LK2.P3.y;g_LK4.b=0

25、;g_LK4.c=0;g_LK4.P.x=2*org.x+2*R-g_LK1.P.x;g_LK4.P.y=g_LK1.P.y;g_LK4.P1.x=2*org.x+2*R-g_LK1.P2.x;g_LK4.P1.y=g_LK1.P2.y;g_LK4.P2.x=2*org.x+2*R-g_LK1.P1.x;g_LK4.P2.y=g_LK1.P1.y;g_LK4.P3.x=2*org.x+2*R-g_LK1.P4.x;g_LK4.P3.y=g_LK1.P4.y;g_LK4.P4.x=2*org.x+2*R-g_LK1.P3.x;g_LK4.P4.y=g_LK1.P3.y;for(int i=0;i

26、5;i+)POINT cr;int nx=(g_LKi.P3.x-g_LKi.P4.x)/5;int ny=(g_LKi.P3.y-g_LKi.P4.y)/5;for(int j=0;j4;j+)cr.x=g_LKi.P3.x-nx-nx*j;cr.y=g_LKi.P3.y-ny-ny*j;g_LKi.PTj.x=cr.x;g_LKi.PTj.y=cr.y;/Ellipse(hdc,cr.x-R/40,cr.y-R/40,cr.x+R/40,cr.y+R/40);void DrawArrowLen(HDC hdc,POINT p1,POINT p2)POINT pt5,tmp;HBRUSH b

27、r,br1,oldbr;int dx1,dx2,dy1,dy2;double k1,k2,L;double pi = 3.1415926535; double tp=(p1.x-p2.x)*(p1.x-p2.x)+(p1.y-p2.y)*(p1.y-p2.y);L=sqrt(tp);k1=20*sin(pi*10/180)/L;k2=20*cos(pi*10/180)/L;dy1=k1*(p1.x-p2.x)+k2*(p1.y-p2.y);dx1=k2*(p1.x-p2.x)-k1*(p1.y-p2.y);dy2=k2*(p1.y-p2.y)-k1*(p1.x-p2.x);dx2=k2*(p1

28、.x-p2.x)+k1*(p1.y-p2.y);/在底部画下个三角形,高度为方格的1/4,作为旗的底座pt0.x=p2.x+dx1;pt0.y=p2.y+dy1;/(cellRect.bottom-cellRect.top)*3/4pt1.x=p2.x;pt1.y=p2.y;pt2.x=p2.x+dx2;pt2.y=p2.y+dy2; MoveToEx(hdc,p1.x,p1.y,&tmp);LineTo(hdc,p2.x,p2.y);br=CreateSolidBrush(RGB(0,0,0);oldbr=(HBRUSH)SelectObject(hdc,br);Polygon(hdc,pt

29、,3);SelectObject(hdc,oldbr);void DrawLk(HDC hdc,HWND hWnd)POINT tmp;initdata(hWnd);for(int i=0;i5;i+)MoveToEx(hdc,g_LKi.P1.x,g_LKi.P1.y,&tmp);LineTo(hdc,g_LKi.P3.x,g_LKi.P3.y);MoveToEx(hdc,g_LKi.P2.x,g_LKi.P2.y,&tmp);LineTo(hdc,g_LKi.P4.x,g_LKi.P4.y);MoveToEx(hdc,g_LK0.P3.x,g_LK0.P3.y,&tmp);LineTo(h

30、dc,g_LK1.P3.x,g_LK1.P3.y);MoveToEx(hdc,g_LK1.P4.x,g_LK1.P4.y,&tmp);LineTo(hdc,g_LK2.P3.x,g_LK2.P3.y);MoveToEx(hdc,g_LK2.P4.x,g_LK2.P4.y,&tmp);LineTo(hdc,g_LK3.P3.x,g_LK3.P3.y);MoveToEx(hdc,g_LK3.P4.x,g_LK3.P4.y,&tmp);LineTo(hdc,g_LK4.P3.x,g_LK4.P3.y);MoveToEx(hdc,g_LK4.P4.x,g_LK4.P4.y,&tmp);LineTo(h

31、dc,g_LK0.P4.x,g_LK0.P4.y);TextOutW(hdc,g_LK0.P1.x+20,g_LK0.P1.y,LC,2);TextOut(hdc,g_LK1.P2.x,g_LK1.P2.y-20,B,1);TextOut(hdc,g_LK2.P1.x+20,g_LK2.P1.y,A,1);TextOutW(hdc,g_LK3.P1.x+20,g_LK3.P1.y-20,LE,2);TextOut(hdc,g_LK4.P1.x-20,g_LK4.P1.y-20,D,1);/画顺时针连线HPEN pen,oldpen;pen= CreatePen(PS_SOLID,5,RGB(0

32、,255,255); oldpen=(HPEN)SelectObject(hdc,pen); DrawArrowLen(hdc,g_LK1.PT3,g_LK2.PT0);DrawArrowLen(hdc,g_LK3.PT3,g_LK4.PT0);DrawArrowLen(hdc,g_LK4.PT3,g_LK0.PT3);SelectObject(hdc,oldpen);/画交通线HPEN pen,pen1,oldpen;pen= CreatePen(PS_SOLID,5,RGB(0,255,255);/pen1= CreatePen(PS_SOLID,10,RGB(0,255,255); ol

33、dpen=(HPEN)SelectObject(hdc,pen);switch(nSt)case 0:break;case 1:DrawArrowLen(hdc,g_LK1.PT0,g_LK0.PT0); DrawArrowLen(hdc,g_LK1.PT1,g_LK4.PT2);/DrawArrowLen(hdc,g_LK1.PT2,g_LK3.PT1);/DrawArrowLen(hdc,g_LK1.PT3,g_LK2.PT0);break;case 2:POINT pt1,pt2;pt1.x=g_LK2.PT0.x+10;pt1.y=g_LK2.PT0.y;pt2.x=g_LK1.PT3

34、.x+10;pt2.y=g_LK1.PT3.y; DrawArrowLen(hdc,pt1,pt2);DrawArrowLen(hdc,g_LK2.PT1,g_LK0.PT1);DrawArrowLen(hdc,g_LK2.PT2,g_LK4.PT1);break;case 3:DrawArrowLen(hdc,g_LK3.PT0,g_LK2.PT3);DrawArrowLen(hdc,g_LK3.PT1,g_LK1.PT2);DrawArrowLen(hdc,g_LK3.PT2,g_LK0.PT2);DrawArrowLen(hdc,g_LK3.PT3,g_LK4.PT0);break;ca

35、se 4:DrawArrowLen(hdc,g_LK4.PT1,g_LK2.PT2);DrawArrowLen(hdc,g_LK4.PT2,g_LK1.PT1);DrawArrowLen(hdc,g_LK4.PT3,g_LK0.PT3);break;SelectObject(hdc,oldpen);HBRUSH burred,burgreen,oldbur; burred=CreateSolidBrush(RGB(255,0,0);burgreen=CreateSolidBrush(RGB(0,255,0);oldbur=(HBRUSH)SelectObject(hdc,burgreen);f

36、or(int i=1;i5;i+) if(i=nSt) SelectObject(hdc,burgreen); else SelectObject(hdc,burred); for(int j=0;j4;j+) Ellipse(hdc,g_LKi.PTj.x-R/40,g_LKi.PTj.y-R/40,g_LKi.PTj.x+R/40,g_LKi.PTj.y+R/40);SelectObject(hdc,oldbur);/RECT rect;void DrawSec(HDC hdc)POINT orgc;RECT rect;HFONT font,oldfont;char str3;orgc.x

37、=org.x+R;orgc.y=org.y+R;rect.left=orgc.x-R/10; rect.top=orgc.y-R/10;rect.right=orgc.x+R/10; rect.bottom=orgc.y+R/10;FillRect(hdc,&rect,CreateSolidBrush(RGB(255,255,255);sprintf(str,%d,nSec);font=CreateFont(rect.bottom-rect.top, 0,0,0,FW_NORMAL,FALSE,FALSE,0,ANSI_CHARSET,OUT_DEFAULT_PRECIS,CLIP_DEFAU

38、LT_PRECIS,DEFAULT_QUALITY,DEFAULT_PITCH | FF_SWISS,黑体);oldfont=(HFONT)SelectObject(hdc,font);SetTextColor(hdc,RGB(0,0,255);SetBkMode(hdc,TRANSPARENT);DrawText(hdc,str,1,&rect,DT_CENTER);SelectObject(hdc,oldfont);DeleteObject(font);(4)总结:本题主要部分是直接用C+语言实现的一个设计,由于采用数组作为的存储结构,因此程序较为简洁。若完全借助于实验工具,程序将更为简洁。然而,数组作为图的存储结构要求在编写程序时必须要紧记其数组下标所对应的路口,更重要的是浪费了一些存储空间。这是本实验设计的缺陷。解决的办法是将数组改为指针,从而在程序运行时节省存储空间。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 办公文档 > 其他范文


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号