鐵路課程設計
1. 數據結構課程設計 鐵路票務管理系統
#include<fstream>
#include<iostream>
#include<string>
#include<stdio.h>
#include<iomanip>
#define SIZE_view 50
#define SIZE_line 100
#define SIZE_way 300
#define MAXNODE 30 //定義最多的頂點數
#define MAXCOST 1000
//自己寫的頭文件
//#include<addview.h>// //
using namespace std;
struct view_info /*城市信息結構*/
{
int id;
char name[20];
int code;
char shortname[20];
char LName[100];// 經過此車站的鐵路線名稱
} views[SIZE_view];
struct line_info //鐵路線信息結構
{
int Lid;
char LName[20];
int start_id; //始發站id
int end_id; //終點站id
int dist; //鐵路線長度
int sign;//通行標志
}lines[SIZE_line];
struct way_info //鐵路度的信息結構
{
int station1;
int station2;
int dist;
}ways[SIZE_way];
struct path_info //用於最短路徑的查詢
{
int count;
int path[SIZE_view];
};
int view_count,line_count,way_count;//用來存儲文件中有多少條記錄
void readviews()
{
int i;
ifstream infile("views.txt",ios::in); //打開文件
infile >>view_count ; //把文件中的記錄賦值給view_count
if(!infile) //打開文件失敗
{
cerr<<"open error!"<<endl;
exit(1);
}
//infile>>view_count; // 先讀入文件個數
for(i=0;i<view_count;i++)
{
infile>>views[i].id>>views[i].name>>views[i].code>>views[i].shortname>>views[i].LName;
}
//view_count=i;//給出原文件中車站的個數
infile.close();
cout<<" "<<"id"<<" "<<"name"<<" "<<"code"<<" "<<"shortname"<<" "<<"LName"<<endl;
for(i=0;i<view_count;i++)
cout<<" "<<views[i].id<<" "<<views[i].name<<" "<<views[i].code
<<" "<<views[i].shortname<<" "<<views[i].LName<<endl;
}
void readways() //讀文件ways.txt
{
int i;
ifstream infile("ways.txt",ios::in); //打開文件
infile>>way_count; ////把文件中的記錄賦值給way_count
if(!infile) //打開文件失敗
{
cerr<<"open error!"<<endl;
exit(1);
}
for(i=0;i<way_count;i++)
infile>>ways[i].station1>>ways[i].station2>>ways[i].dist;
infile.close();
//測試用,輸出路段的信息
cout<<" "<<"station1"<<" "<<"station2"<<" "<<"dist"<<endl;
for(i=0;i<way_count;i++)
cout<<" "<<ways[i].station1<<" "<<ways[i].station2<<" "<<ways[i].dist<<endl ;
}
void readlines() //讀文件lines.txt
{
int i;
ifstream infile("lines.txt",ios::in); //打開文件
infile>>line_count; //把文件中的記錄賦值給line_count
if(!infile) //打開文件失敗
{
cerr<<"open error!"<<endl;
exit(1);
}
for(i=0;i<line_count;i++)
infile>>lines[i].Lid>>lines[i].LName>>lines[i].start_id>>lines[i].end_id>>lines[i].dist>>lines[i].sign;
infile.close();
/*
cout<<" "<<"Lid"<<" "<<"LName"<<" "<<"start_id"<<" "<<"end_id"<<" "<<"dist"<<" "<<"sign"<<endl;
for(i=0;i<view_count;i++)
cout<<" "<<lines[i].Lid<<" "<<lines[i].LName<<" "<<lines[i].start_id
<<" "<<lines[i].end_id<<" "<<lines[i].dist<<" "<<lines[i].sign<<endl;
*/ //這里是輸出文件中的信息
}
void search () //查詢車站信息(所在的鐵路線)
{
cout<<"please enter the station name:";
char sta_name[20];
cin>>sta_name; //輸入要查詢的名字
cout<<endl;
ifstream infile("views.txt ",ios::in); //讀文件
infile >>view_count ; //讀出文件記錄的個數
if(!infile) //打開文件失敗
{
cerr<<"open error!"<<endl;
exit(1);
}
int i,mark;
for(i=0;i<view_count;i++)
infile>>views[i].id>>views[i].name>>views[i].code>>views[i].shortname>>views[i].LName;
infile.close();
for(i=0;i< view_count;i++)
{
if(strcmp(sta_name,views [i].name)==0) //找到車站
{
cout<<"the station's informations is:\n"<<endl;
cout<<" "<<"id"<<" "<<"name"<<" "<<"code"<<" "<<"shortname"<<" "<<"LName"<<endl;
cout<<" "<<views[i].id<<" "<< views[i].name<<" "<< views [i].code
<<" "<< views [i].shortname<<" "<< views [i].LName <<endl;
break;
}
mark=i;
}
if(mark==( view_count -1)) //若沒有找到,輸出提示
{
cout<<"sorry,the station is not in here"<<endl;
}
}
void addview()
{
cout<<"please enter the new view's informations:"<<endl; //輸入新車站信息
cout<<"id:";
cin>>views[view_count].id;
cout<<"name:";
cin>>views[view_count].name;
cout<<"code:";
cin>>views[view_count].code;
cout<<"shortname:";
cin>>views[view_count].shortname;
cout<<"LName:";
cin>>views[view_count].LName;
ofstream outfile("views.txt",ios::app); //打開views文件,並且寫入數據
outfile<<view_count<<endl;
if(!outfile) //文件打開失敗
{
cerr<<"open error!"<<endl;
exit(1);
}
outfile<<views[view_count].id<<" "<<views[view_count].name<<" "<<views[view_count].code
<<" " <<views[view_count].shortname<<" "<<views[view_count].LName<<endl;
//在文件末尾添加
view_count=view_count+1;
outfile.close(); //關閉文件
cout<<"successfully! the new station is added"<<endl;
cout<<"now station number is:"<<view_count<<endl;
}
void addway()
{
cout<<"please enter the new way's informations:"<<endl; //輸入新車站信息
cout<<"station1:";
cin>>ways[way_count].station1; // station1的id
cout<<"station2:";
cin>>ways[way_count].station2; //station2的id
cout<<"dist:";
cin>>ways[way_count].dist; //路段的長度
ofstream outfile("ways.txt",ios::app); //打開way.txt文件
outfile<<way_count<<endl;
if(!outfile) //文件打開失敗
{
cerr<<"open error!"<<endl;
exit(1);
}
outfile<<ways[way_count].station1<<" "<<ways[way_count].station2<<" "<<ways[way_count].dist;
//在文件末尾添加
outfile.close(); //關閉文件
cout<<"successfully! the new station is added"<<endl;
way_count=way_count+1;
cout<<"now station number is:"<<view_count<<endl;
}
void addline()
{
cout<<"please enter the new line's informations:"<<endl; //輸入新鐵路線信息
cout<<"Lid:";
cin>>lines[line_count].Lid;
cout<<"LName:";
cin>>lines[line_count].LName;
cout<<"start_id:";
cin>>lines[line_count].start_id;
cout<<"end_id:";
cin>>lines[line_count].end_id;
cout<<"dist:";
cin>>lines[line_count].dist;
cout<<"sign:";
cin>>lines[line_count].sign;
ofstream outfile("lines.txt",ios::app); //打開文件
outfile <<line_count << endl;
if(!outfile) //文件打開失敗
{
cerr<<"open error!"<<endl;
exit(1);
}
outfile<<lines[line_count].Lid<<" "<<lines[line_count].LName<<" "<<lines[line_count].start_id
<<" " <<lines[line_count].end_id<<" "<<lines[line_count].dist<<lines[line_count].sign<<endl;
//在文件末尾添加
outfile.close(); //關閉文件
cout<<"successfully! the new line is added"<<endl;
line_count=line_count+1;
cout<<"now line number is:"<<line_count<<endl;
}
//-----------------------------------------------------------------------------------
void floyed() //弗洛伊德(Floyed)演算法
{
int i, j, k, m, start_num, end_num; //i,j用來表示起始點和終點
int dist_list[SIZE_view][SIZE_view]; //定義了一個數組
view_count=view_count+1;
struct path_info path_list[SIZE_view][SIZE_view]; //定義了一個path_info結構的變數,包含著count和path[]用來存儲經過的路徑
for(i=1;i<=view_count;i++) //這里開始讀文件,先讓所有的線都為最大值
for(j=1;j<=view_count;j++)
dist_list[i][j]=MAXCOST;
for(int t=0;t<=way_count;t++)
{
i=ways[t].station1;
j=ways[t].station2;
dist_list[i][j]=ways[t].dist;//把文件中的數據賦值給dist_list[i][j]=ways[t].dist;形式
}
for (i =0; i< view_count; i++)
{
for (j= 0; j<view_count; j++)
{
if (i == j)
{
dist_list[i][j] = 0;
continue;
}
dist_list[i][j] = -1;
path_list[i][j].count = 0;
for (k = 0; k< way_count; k++) //
{
if (ways[k].station1 == i && ways[k].station2 == j) //把起始點和終點分別給予i,j
{
dist_list[i][j] = ways[k].dist;
path_list[i][j].count = 2;
path_list[i][j].path[0] = i;
path_list[i][j].path[1] = j;
break;
}
}
}
}
for (k = 0; k<= view_count-1; k++)
{
for (i = 0; i < view_count; i++)
for (j = 0; j< view_count; j++)
{
if (i == k || j == k || i == j)
continue;
if (dist_list[i][k] == -1 || dist_list[k][j] == -1)
continue;
if ( (dist_list[i][j] == -1) ||
((dist_list[i][j] != -1) &&(dist_list[i][k] + dist_list[k][j] < dist_list[i][j])))
{
dist_list[i][j] = dist_list[i][k] + dist_list[k][j];
// shortest[i][j]=shortest[i][k]+shortest[k][j];
path_list[i][j].count = path_list[i][k].count + path_list[k][j].count - 1;
// path[i][j]=k;
for (m = 0; m < path_list[i][k].count; m++)
path_list[i][j].path[m] = path_list[i][k].path[m];
for (m = 0; m < path_list[k][j].count; m++)
path_list[i][j].path[m+path_list[i][k].count] = path_list[k][j].path[m+1];
}
}
}
cout<<" Floyed table:\n";
cout<<" All views in the school:\n";
for (i = 0; i < view_count-1; i++)
cout<<" "<<i+1<<":"<<views[i].name<<endl;
cout<<" Please input the start number: ";
cin>>start_num;
cout<<" Please input the end number: ";
cin>>end_num;
cout<<endl<<endl;
cout<<"From"<<views[start_num-1].name<<"to"<<views[end_num-1].name;
if (dist_list[start_num][end_num] == -1)
cout<<"no way."<<endl;
else
{
cout<<"distance is "<<dist_list[start_num][end_num]<<", and path is :";//dist_list[][]用來表示兩點間的長度
k = path_list[start_num][end_num].path[0]-1; //path_list[][]用來保存路徑path[m]在這里表明是通過的那個車站的
cout<<views[k].name;
for (m = 1; m < path_list[start_num][end_num].count; m++)
{
k = path_list[start_num][end_num].path[m]-1; //這里應該也是int型,k是經過的路徑的id
cout<<"->"<<views[k].name;
}
}
cout<<endl<<endl;
}
void main()
{
readviews();
readlines() ;
readways();
while(1)
{
int menu;
cout<<endl<<endl<<endl<<endl;
cout<<" 全國鐵路運輸網最佳經由系統 "<<endl;
cout<<"**********************************************************"<<endl;
cout<<" 1:增加車站信息 "<<endl;
cout<<" 2:增加鐵路線信息 "<<endl;
cout<<" 3:查詢車站信息 "<<endl;
cout<<" 4:查詢最短路徑 "<<endl;
cout<<" 5:退出界面 "<<endl;
cout<<"**********************************************************"<<endl;
cout<<"輸入要進行的操作的代碼(1--5):"<<endl;
cin>>menu;
while(menu<1||menu>5)
{
cout<<"error!please enter again:";
cin>>menu;
}
switch(menu)
{
case 1:
while(1)
{
addview();
while (1)
{
addway();
cout<<"do you want to continue (y/n) "<<endl;
char con ;
cin>>con;
if(con=='y')
addway();
else
break;
}
cout<<"do you want to continue (y/n) "<<endl;
char con ;
cin>>con;
if(con=='y')
addview();
else
break;
}
break;
case 2:
while(1)
{
addline();
cout<<"do you want to continue (y/n) "<<endl;
char con ;
cin>>con;
if(con=='y')
addline();
else
break;
}
break;
case 3:
while(1)
{
search ();
cout<<"do you want to continue (y/n) "<<endl;
char con ;
cin>>con;
if(con=='y')
search ();
else
break;
}
break;
case 4:
while(1)
{
floyed();
cout<<"do you want to continue (y/n) "<<endl;
char con ;
cin>>con;
if(con=='y')
floyed();
else
break;
}
break;
case 5:
{
cout<<"謝謝使用,再見!"<<endl;
exit(1);
}
}
}
}
2. 鐵路選線課程設計珠河鎮到後河鎮,i=12%。的平面圖和縱斷面圖怎麼畫啊
用 AutoCad2014
3. 鐵路線路專業設計 需要學習哪些課程!!! 請各位大大幫忙!!
土木工程 CAD工程制圖 工程材料 測量 高速鐵路概論 橋梁~~~多的很~~~~
我現在就在鐵路工程單位上班 其實不用怎麼學 到工作地方慢慢學習實踐 書上的東西跟實踐不一樣 只要知道最基本的東西 比如說 一般鐵路軌距是多少 1435
最重要的你是設計 也就是畫圖 就是CAD 你應該一學就會 計算機專業的嗎
一開始工作不可能讓你直接去畫圖的 你只能跟著你的同事慢慢學以後
到啦你學的差不多的時候才有可能讓你參與到真正的畫圖中去~~~~~
4. 求西南交通大學鐵路選線課程設計圖紙,萬分感謝
關於流言我裝作無動於衷
5. 課程設計,做一個鐵路客運售票系統,用java做,我完全不知道這個怎麼做,求一高手指點一下,我要瘋了
先設計資料庫表,然後用SSH框架實實現,這是大的思路,具體的細節還很多,你自己多網路一下,查查資料就能找到。
6. 鐵路選線課程設計時,隧道內可不可以設曲線
選線我學過,隧道內可以設曲線,我們東北就有很多隧道里是曲線的.
7. 我今年大四,課題是鐵路10KV 配電所及自閉線路的設計。我需要一些配電所的知識,還有它的規范,進了中國知
畢業設計吧?多去圖書館查下資料吧!向你的指導老師要點資料,老師的資料很多滴!
8. 語文六上人教版第5課詹天佑設計的鐵路 說說鐵路爬陡坡的辦法。 最好附圖片,清楚些。
鐵路爬坡的辦法,你問的只是修鐵路嗎?有沒有問到開火車呢?其實,這些問題通過詹天佑的人字形鐵路,也全都可以看出來了。
我出生在湖北武漢以後,爸爸轉到廣州工作,從小我每年都要坐火車,加上武漢市修建了一座座的長江大橋,我不僅是火車的發燒友,對火車,對鐵路,對橋梁都大有興趣。九十年代我學的課文中,詹天佑的故事我記得相當清楚,一些段落我到今天還能開口背誦。
「哪裡要開山,哪裡要架橋,哪裡要把陡坡鏟平,哪裡要把彎度改小……都要經過周密的計算」。從目前的形勢來看,陡坡鏟平好像已經用得不多了,看看《武廣客運專線(高鐵)介紹》的視頻,為了減少對地面的影響,橋梁與隧道在全程中佔了一大半的里程,鐵路爬坡,目前也多半是修橋。
修橋表面看好像工程大,實際上也減少了鐵路受地面的影響。我們看看4月份,江西滬昆鐵路列車脫軌的事故,就是因為陡坡鏟平,火車靠在高山旁邊行駛,大雨造成山體滑坡,結果就對鐵路造成了危險。
「鐵路經過青龍橋附近,坡度特別大,詹天佑順著山勢,修建了一種人字形鐵路……北上的列車到了南口就用兩個火車頭,一個在前面拉,一個在後面推。過青龍橋,列車折向西北前進。過了人字形鐵路的叉道口就反過來,列車折向東北前進,原先推的火車頭拉,原先拉的火車頭推。」
詹天佑修鐵路的這個辦法,就是順著山勢,讓火車靠在高山旁邊爬坡,從而減少陡坡鏟平。可是這樣的辦法,靠在高山旁邊,如果發生山體滑坡,把鐵路埋了,火車就容易發生事故,所以今天多半都要修橋。
如果問火車怎麼爬坡,詹天佑的故事裡面也看到了,就要讓更多的車輪變成有動力的轉起來。增加一個火車頭,就是要在列車當中,增加一些有動力的車輪。或者說,一個工人用一條扁擔獨自挑兩簧土,兩個工人用一條扁擔共同抬一簧土,當然是兩個人一同抬一簧的感覺輕一點兒。簡單說來,這也就是「一個和尚挑水吃,兩個和尚抬水吃」的形象。
這個道理對火車也是一樣的。幾十節車廂的負擔,不要全部交給前面的一個火車頭,還是讓後面多一個火車頭一同使勁兒,就把一簧土變輕了。目前在武廣客運專線的高鐵上,跑的都是動車組,以前火車跑得快,全憑車頭帶的事實一去不復返,時速350千米的動車組,每節車廂都有動力,這樣讓列車力氣大,跑得快,上坡也就不怕重了。
相比之下,看看武漢的天興洲大橋,就因為除了客運高鐵的雙線,還有貨運的雙線,一共四線的公路鐵路兩用橋。因為貨車比客車重得多,貨車還要比客車長好多,所以貨運火車頭的負荷更大,大橋就要為貨車減少坡度。
總之,要讓鐵路爬坡,就要降低坡度,目前可能優先選擇架橋。要讓火車爬坡,就要多幾個車輪一起開動,多幾個人一同使勁,正如兩個人一起抬土,感覺就會輕一些,上坡也就輕松一些。