久久99精品久久久久久琪琪,久久人人爽人人爽人人片亞洲,熟妇人妻无码中文字幕,亚洲精品无码久久久久久久

c語(yǔ)言一朵花源代碼

時(shí)間:2019-05-15 02:00:44下載本文作者:會(huì)員上傳
簡(jiǎn)介:寫(xiě)寫(xiě)幫文庫(kù)小編為你整理了多篇相關(guān)的《c語(yǔ)言一朵花源代碼》,但愿對(duì)你工作學(xué)習(xí)有幫助,當(dāng)然你在寫(xiě)寫(xiě)幫文庫(kù)還可以找到更多《c語(yǔ)言一朵花源代碼》。

第一篇:c語(yǔ)言一朵花源代碼

/////////////////////////////////////////////////// // 程序名稱(chēng):一束漂亮的花

// 編譯環(huán)境:Visual C++ 6.0 / 2010,EasyX 2011驚蟄版 // 作

者:yangw80 // 最后修改:2011-9-29 // #include #include #include

#define PI 3.14159265

// 畫(huà) 花朵

void flower(int x, int y, COLORREF c){ int x1, y1, x2, y2;int d = 15;double e;setcolor(c);for(double a = 0;a < 2 * PI;a += PI / 360){ e = d *(1 + sin(a * 5));x1 = int(x + e * cos(a));y1 = int(y + e * sin(a));x2 = int(x + e * cos(a + PI / 5));y2 = int(y + e * sin(a + PI / 5));line(x1, y1, x2, y2);}

// 畫(huà) 蝴蝶結(jié)

void tie(int x, int y, COLORREF c){ int x1, y1, x2, y2;} int d = 80;double e;setcolor(c);for(double a = 0;a < 2 * PI;a += PI / 360){ e = d *(1 + sin(a * 4));x1 = int(x + e * cos(a));y1 = int(y + e * sin(a)/ 2);x2 = int(x + e * cos(a + PI / 9));y2 = int(y + e * sin(a + PI / 9)/ 4.5);line(x1, y1, x2, y2);}

// 主函數(shù) void main(){

// 畫(huà)花朵

flower(320, 160, RED);flower(200, 120, YELLOW);flower(150, 140, LIGHTRED);flower(430, 176, RGB(255, 127, 0));flower(370, 110, RGB(239, 179, 52));flower(250, 72, RGB(235, 95, 186));initgraph(640, 480);

// 畫(huà)枝干

setcolor(GREEN);line(189, 372, 180, 400);line(310, 160, 325, 68);line(310, 160, 187, 374);line(150, 140, 189, 374);line(430, 176, 190, 374);line(370, 110, 187, 374);line(250, 72, 189, 372);line(253, 192, 190, 374);line(189, 372, 187, 400);line(189, 372, 182, 400);line(189, 372, 200, 120);}

} flower(325, 68, RGB(228, 119, 98));flower(253, 190, RGB(247, 169, 117));// 畫(huà)蝴蝶結(jié)

tie(195, 354, LIGHTMAGENTA);

// 按任意鍵退出 getch();closegraph();

第二篇:C語(yǔ)言?huà)呃自创a

C語(yǔ)言?huà)呃自创a.txt如果背叛是一種勇氣,那么接受背叛則需要更大的勇氣。愛(ài)情是塊磚,婚姻是座山。磚不在多,有一塊就靈;山不在高,守一生就行。#include #include #include #include

/*鼠標(biāo)信息宏定義*/ #define WAITING 0xff00 #define LEFTPRESS 0xff01 #define LEFTCLICK 0xff10 #define LEFTDRAG 0xff19 #define RIGHTPRESS 0xff02 #define RIGHTCLICK 0xff20 #define RIGHTDRAG 0xff2a #define MIDDLEPRESS 0xff04 #define MIDDLECLICK 0xff40 #define MIDDLEDRAG 0xff4c #define MOUSEMOVE 0xff08 struct { int num;/*格子當(dāng)前處于什么狀態(tài),1有雷,0已經(jīng)顯示過(guò)數(shù)字或者空白格子*/ int roundnum;/*統(tǒng)計(jì)格子周?chē)卸嗌倮?/ int flag;/*右鍵按下顯示紅旗的標(biāo)志,0沒(méi)有紅旗標(biāo)志,1有紅旗標(biāo)志*/ }Mine[10][10];

int gameAGAIN=0;/*是否重來(lái)的變量*/ int gamePLAY=0;/*是否是第一次玩游戲的標(biāo)志*/ int mineNUM;/*統(tǒng)計(jì)處理過(guò)的格子數(shù)*/ char randmineNUM[3];/*顯示數(shù)字的字符串*/

int Keystate;int MouseExist;int MouseButton;int MouseX;int MouseY;int up[16][16],down[16][16],mouse_draw[16][16],pixel_save[16][16];

void MouseMath()/*計(jì)算鼠標(biāo)的樣子*/ {int i,j,jj,k;long UpNum[16]={ 0x3fff,0x1fff,0x0fff,0x07ff, 0x03ff,0x01ff,0x00ff,0x007f, 0x003f,0x00ff,0x01ff,0x10ff, 0x30ff,0xf87f,0xf87f,0xfc3f };long DownNum[16]={ 0x0000,0x7c00,0x6000,0x7000, 0x7800,0x7c00,0x7e00,0x7f00, 0x7f80,0x7e00,0x7c00,0x4600, 0x0600,0x0300,0x0300,0x0180 };for(i=0;i<16;i++){ j=jj=15;while(UpNum[i]!=0){ up[i][j]=UpNum[i]%2;j--;UpNum[i]/=2;} while(DownNum[i]!=0){ down[i][jj--]=DownNum[i]%2;DownNum[i]/=2;} for(k=j;k>=0;k--)up[i][k]=0;for(k=jj;k>=0;k--)down[i][k]=0;for(k=0;k<16;k++)/*四種組合方式*/ { if(up[i][k]==0&&down[i][k]==0)mouse_draw[i][k]=1;else if(up[i][k]==0&&down[i][k]==1)mouse_draw[i][k]=2;else if(up[i][k]==1&&down[i][k]==0)mouse_draw[i][k]=3;else mouse_draw[i][k]=4;} } mouse_draw[1][2]=4;/*特殊點(diǎn)*/ }

void Init(void);/*圖形驅(qū)動(dòng)*/ void MouseOn(int,int);/*鼠標(biāo)光標(biāo)顯示*/ void MouseOff(void);/*鼠標(biāo)光標(biāo)隱藏*/ void MouseSetXY(int,int);/*設(shè)置當(dāng)前位置*/ int LeftPress(void);/*左鍵按下*/ int RightPress(void);/*鼠標(biāo)右鍵按下*/ int MiddlePress();void MouseGetXY(void);/*得到當(dāng)前位置*/ int MouseStatus();void Control(void);/*游戲開(kāi)始,重新,關(guān)閉*/ void GameBegain(void);/*游戲開(kāi)始畫(huà)面*/ void DrawSmile(void);/*畫(huà)笑臉*/ void DrawRedflag(int,int);/*顯示紅旗*/ void DrawEmpty(int,int,int,int);/*兩種空格子的顯示*/ void GameOver(void);/*游戲結(jié)束*/ void GameWin(void);/*顯示勝利*/ int MineStatistics(int,int);/*統(tǒng)計(jì)每個(gè)格子周?chē)睦讛?shù)*/ int ShowWhite(int,int);/*顯示無(wú)雷區(qū)的空白部分*/ void GamePlay(void);/*游戲過(guò)程*/ void Close(void);/*圖形關(guān)閉*/

void main(void){ Init();MouseMath();//MouseOn(MouseX,MouseY);Control();Close();}

void Init(void)/*圖形開(kāi)始*/ { int gd=DETECT,gm;registerbgidriver(EGAVGA_driver);initgraph(&gd,&gm,“");} void Close(void)/*圖形關(guān)閉*/ { closegraph();} /*鼠標(biāo)光標(biāo)顯示*/ void MouseOn(int x,int y){ int i,j;int color;

for(i=0;i<16;i++)/*畫(huà)鼠標(biāo)*/ { for(j=0;j<16;j++){ pixel_save[i][j]=getpixel(x+j,y+i);/*保存原來(lái)的顏色*/ if(mouse_draw[i][j]==1)putpixel(x+j,y+i,0);else if(mouse_draw[i][j]==2)putpixel(x+j,y+i,15);} } } /*隱藏鼠標(biāo)*/ void MouseOff(){ int i,j,x,y,color;x=MouseX;y=MouseY;for(i=0;i<16;i++)/*原位置異或消去*/ for(j=0;j<16;j++){ if(mouse_draw[i][j]==3||mouse_draw[i][j]==4)continue;color=getpixel(x+j,y+i);putpixel(x+j,y+i,color^color);putpixel(x+j,y+i,pixel_save[i][j]);} } void MouseSetXY(int x,int y)/*設(shè)置當(dāng)前位置*/ { _CX=x;_DX=y;_AX=0x04;geninterrupt(0x33);} int LeftPress(void)/*鼠標(biāo)左鍵按下*/ { _AX=0x03;geninterrupt(0x33);return(_BX&1);} int RightPress(void)/*鼠標(biāo)右鍵按下*/ { _AX=0x03;geninterrupt(0x33);return(_BX&2);} /*是否按下中鍵

返回值同上 */ int MiddlePress(){ _AX=0x03;geninterrupt(0x33);return(_BX&4);} void MouseGetXY(void)/*得到當(dāng)前位置*/ { _AX=0x03;geninterrupt(0x33);MouseX=_CX;MouseY=_DX;} /*鼠標(biāo)按鍵情況,返回0表示只移動(dòng),返回1表示左右鍵同時(shí)按下,2表示只按了左鍵,3表示只按了右鍵*/

int MouseStatus(){ int x,y;int status;int press=0;

int i,j,color;status=0;/*默認(rèn)鼠標(biāo)沒(méi)有移動(dòng)*/

x=MouseX;y=MouseY;

while(x==MouseX&&y==MouseY&&status==0&&press==0){ if(LeftPress()&&RightPress())press=1;else if(LeftPress())press=2;else if(RightPress())press=3;MouseGetXY();if(MouseX!=x||MouseY!=y)status=1;} if(status)/*移動(dòng)情況才重新顯示鼠標(biāo)*/ { for(i=0;i<16;i++)/*原位置異或消去*/ for(j=0;j<16;j++){ if(mouse_draw[i][j]==3||mouse_draw[i][j]==4)continue;color=getpixel(x+j,y+i);putpixel(x+j,y+i,color^color);putpixel(x+j,y+i,pixel_save[i][j]);} MouseOn(MouseX,MouseY);/*新位置顯示*/ } if(press!=0)/*有按鍵的情況*/ return press;return 0;/*只移動(dòng)的情況*/ }

void Control(void)/*游戲開(kāi)始,重新,關(guān)閉*/ { int gameFLAG=1;/*游戲失敗后判斷是否重新開(kāi)始的標(biāo)志*/ while(1){ MouseStatus();if(gameFLAG)/*游戲失敗后沒(méi)判斷出重新開(kāi)始或者退出游戲的話(huà)就繼續(xù)判斷*/ {

GameBegain();/*游戲初始畫(huà)面*/ GamePlay();/*具體游戲*/ if(gameAGAIN==1)/*游戲中重新開(kāi)始*/ { gameAGAIN=0;continue;} }

gameFLAG=0;if(LeftPress())/*判斷是否重新開(kāi)始*/ { if(MouseX>280&&MouseX<300&&MouseY>65&&MouseY<85){ gameFLAG=1;continue;} } if(kbhit())/*判斷是否按鍵退出*/ break;} } void DrawSmile(void)/*畫(huà)笑臉*/ { MouseOff();setfillstyle(SOLID_FILL,YELLOW);fillellipse(290,75,10,10);setcolor(YELLOW);setfillstyle(SOLID_FILL,BLACK);/*眼睛*/ fillellipse(285,75,2,2);fillellipse(295,75,2,2);setcolor(BLACK);/*嘴巴*/ bar(287,80,293,81);MouseGetXY();MouseOn(MouseX,MouseY);} void DrawRedflag(int i,int j)/*顯示紅旗*/ { MouseOff();setcolor(7);setfillstyle(SOLID_FILL,RED);bar(198+j*20,95+i*20,198+j*20+5,95+i*20+5);setcolor(BLACK);line(198+j*20,95+i*20,198+j*20,95+i*20+10);MouseGetXY();MouseOn(MouseX,MouseY);} void DrawEmpty(int i,int j,int mode,int color)/*兩種空格子的顯示*/ { MouseOff();setcolor(color);setfillstyle(SOLID_FILL,color);if(mode==0)/*沒(méi)有單擊過(guò)的大格子*/ bar(200+j*20-8,100+i*20-8,200+j*20+8,100+i*20+8);else if(mode==1)/*單擊過(guò)后顯示空白的小格子*/ bar(200+j*20-7,100+i*20-7,200+j*20+7,100+i*20+7);MouseGetXY();MouseOn(MouseX,MouseY);} void GameBegain(void)/*游戲開(kāi)始畫(huà)面*/ { int i,j;cleardevice();if(gamePLAY!=1){ MouseSetXY(290,70);/*鼠標(biāo)一開(kāi)始的位置,并作為它的初始坐標(biāo)*/ MouseX=290;MouseY=70;} gamePLAY=1;/*下次按重新開(kāi)始的話(huà)鼠標(biāo)不重新初始化*/ mineNUM=0;setfillstyle(SOLID_FILL,7);bar(190,60,390,290);for(i=0;i<10;i++)/*畫(huà)格子*/ for(j=0;j<10;j++)DrawEmpty(i,j,0,8);setcolor(7);DrawSmile();/*畫(huà)臉*/ randomize();for(i=0;i<10;i++)/*100個(gè)格子隨機(jī)賦值有沒(méi)有地雷*/ for(j=0;j<10;j++){ Mine[i][j].num=random(8);/*如果隨機(jī)數(shù)的結(jié)果是1表示這個(gè)格子有地雷*/ if(Mine[i][j].num==1)mineNUM++;/*現(xiàn)有雷數(shù)加1*/ else Mine[i][j].num=2;Mine[i][j].flag=0;/*表示沒(méi)紅旗標(biāo)志*/ } sprintf(randmineNUM,”%d“,mineNUM);/*顯示這次總共有多少雷數(shù)*/ setcolor(1);settextstyle(0,0,2);outtextxy(210,70,randmineNUM);mineNUM=100-mineNUM;/*變量取空白格數(shù)量*/ } void GameOver(void)/*游戲結(jié)束畫(huà)面*/ { int i,j;setcolor(0);for(i=0;i<10;i++)for(j=0;j<10;j++)if(Mine[i][j].num==1)/*顯示所有的地雷*/ {

DrawEmpty(i,j,0,RED);setfillstyle(SOLID_FILL,BLACK);MouseOff();fillellipse(200+j*20,100+i*20,7,7);

MouseGetXY();MouseOn(MouseX,MouseY);} } void GameWin(void)/*顯示勝利*/ { setcolor(11);settextstyle(0,0,2);outtextxy(230,30,”YOU WIN!“);} int MineStatistics(int i,int j)/*統(tǒng)計(jì)每個(gè)格子周?chē)睦讛?shù)*/ { int nNUM=0;if(i==0&&j==0)/*左上角格子的統(tǒng)計(jì)*/ { if(Mine[0][1].num==1)nNUM++;if(Mine[1][0].num==1)nNUM++;if(Mine[1][1].num==1)nNUM++;} else if(i==0&&j==9)/*右上角格子的統(tǒng)計(jì)*/ { if(Mine[0][8].num==1)nNUM++;if(Mine[1][9].num==1)nNUM++;if(Mine[1][8].num==1)nNUM++;} else if(i==9&&j==0)/*左下角格子的統(tǒng)計(jì)*/ { if(Mine[8][0].num==1)nNUM++;if(Mine[9][1].num==1)nNUM++;if(Mine[8][1].num==1)nNUM++;} else if(i==9&&j==9)/*右下角格子的統(tǒng)計(jì)*/ { if(Mine[9][8].num==1)nNUM++;if(Mine[8][9].num==1)nNUM++;if(Mine[8][8].num==1)nNUM++;} else if(j==0)/*左邊第一列格子的統(tǒng)計(jì)*/ { if(Mine[i][j+1].num==1)nNUM++;if(Mine[i+1][j].num==1)nNUM++;if(Mine[i-1][j].num==1)nNUM++;if(Mine[i-1][j+1].num==1)nNUM++;if(Mine[i+1][j+1].num==1)nNUM++;} else if(j==9)/*右邊第一列格子的統(tǒng)計(jì)*/ { if(Mine[i][j-1].num==1)nNUM++;if(Mine[i+1][j].num==1)nNUM++;if(Mine[i-1][j].num==1)nNUM++;if(Mine[i-1][j-1].num==1)nNUM++;if(Mine[i+1][j-1].num==1)nNUM++;} else if(i==0)/*第一行格子的統(tǒng)計(jì)*/ { if(Mine[i+1][j].num==1)nNUM++;if(Mine[i][j-1].num==1)nNUM++;if(Mine[i][j+1].num==1)nNUM++;if(Mine[i+1][j-1].num==1)nNUM++;if(Mine[i+1][j+1].num==1)nNUM++;} else if(i==9)/*最后一行格子的統(tǒng)計(jì)*/ { if(Mine[i-1][j].num==1)nNUM++;if(Mine[i][j-1].num==1)nNUM++;if(Mine[i][j+1].num==1)nNUM++;if(Mine[i-1][j-1].num==1)nNUM++;if(Mine[i-1][j+1].num==1)nNUM++;} else/*普通格子的統(tǒng)計(jì)*/ { if(Mine[i-1][j].num==1)nNUM++;if(Mine[i-1][j+1].num==1)nNUM++;if(Mine[i][j+1].num==1)nNUM++;if(Mine[i+1][j+1].num==1)nNUM++;if(Mine[i+1][j].num==1)nNUM++;if(Mine[i+1][j-1].num==1)nNUM++;if(Mine[i][j-1].num==1)nNUM++;if(Mine[i-1][j-1].num==1)nNUM++;} return(nNUM);/*把格子周?chē)还灿卸嗌倮讛?shù)的統(tǒng)計(jì)結(jié)果返回*/ } int ShowWhite(int i,int j)/*顯示無(wú)雷區(qū)的空白部分*/ { if(Mine[i][j].flag==1||Mine[i][j].num==0)/*如果有紅旗或該格處理過(guò)就不對(duì)該格進(jìn)行任何判斷*/ return;mineNUM--;/*顯示過(guò)數(shù)字或者空格的格子就表示多處理了一個(gè)格子,當(dāng)所有格子都處理過(guò)了表示勝利*/ if(Mine[i][j].roundnum==0&&Mine[i][j].num!=1)/*顯示空格*/ { DrawEmpty(i,j,1,7);

Mine[i][j].num=0;} else if(Mine[i][j].roundnum!=0)/*輸出雷數(shù)*/ { DrawEmpty(i,j,0,8);sprintf(randmineNUM,”%d“,Mine[i][j].roundnum);setcolor(RED);MouseOff();outtextxy(195+j*20,95+i*20,randmineNUM);MouseGetXY();MouseOn(MouseX,MouseY);Mine[i][j].num=0;/*已經(jīng)輸出雷數(shù)的格子用0表示已經(jīng)用過(guò)這個(gè)格子*/ return;} /*8個(gè)方向遞歸顯示所有的空白格子*/ if(i!=0&&Mine[i-1][j].num!=1)ShowWhite(i-1,j);if(i!=0&&j!=9&&Mine[i-1][j+1].num!=1)ShowWhite(i-1,j+1);if(j!=9&&Mine[i][j+1].num!=1)ShowWhite(i,j+1);if(j!=9&&i!=9&&Mine[i+1][j+1].num!=1)ShowWhite(i+1,j+1);if(i!=9&&Mine[i+1][j].num!=1)ShowWhite(i+1,j);if(i!=9&&j!=0&&Mine[i+1][j-1].num!=1)ShowWhite(i+1,j-1);if(j!=0&&Mine[i][j-1].num!=1)ShowWhite(i,j-1);if(i!=0&&j!=0&&Mine[i-1][j-1].num!=1)ShowWhite(i-1,j-1);} void GamePlay(void)/*游戲過(guò)程*/ { int i,j,Num;/*Num用來(lái)接收統(tǒng)計(jì)函數(shù)返回一個(gè)格子周?chē)卸嗌俚乩?/ for(i=0;i<10;i++)for(j=0;j<10;j++)Mine[i][j].roundnum=MineStatistics(i,j);/*統(tǒng)計(jì)每個(gè)格子周?chē)卸嗌俚乩?/ while(!kbhit()){ MouseStatus();if(LeftPress())/*鼠標(biāo)左鍵盤(pán)按下*/ {

if(MouseX>280&&MouseX<300&&MouseY>65&&MouseY<85)/*重新來(lái)*/ {

gameAGAIN=1;break;} if(MouseX>190&&MouseX<390&&MouseY>90&&MouseY<290)/*當(dāng)前鼠標(biāo)位置在格子范圍內(nèi)*/ { j=(MouseX-190)/20;/*x坐標(biāo)*/ i=(MouseY-90)/20;/*y坐標(biāo)*/ if(Mine[i][j].flag==1)/*如果格子有紅旗則左鍵無(wú)效*/ continue;if(Mine[i][j].num!=0)/*如果格子沒(méi)有處理過(guò)*/ { if(Mine[i][j].num==1)/*鼠標(biāo)按下的格子是地雷*/ {

GameOver();/*游戲失敗*/ break;} else/*鼠標(biāo)按下的格子不是地雷*/ {

Num=MineStatistics(i,j);if(Num==0)/*周?chē)鷽](méi)地雷就用遞歸算法來(lái)顯示空白格子*/ ShowWhite(i,j);else/*按下格子周?chē)械乩?/ { MouseOff();sprintf(randmineNUM,”%d",Num);/*輸出當(dāng)前格子周?chē)睦讛?shù)*/ setcolor(RED);outtextxy(195+j*20,95+i*20,randmineNUM);mineNUM--;

MouseGetXY();MouseOn(MouseX,MouseY);}

Mine[i][j].num=0;/*點(diǎn)過(guò)的格子周?chē)讛?shù)的數(shù)字變?yōu)?表示這個(gè)格子已經(jīng)用過(guò)*/ if(mineNUM<1)/*勝利了*/ { GameWin();break;} } } } } if(RightPress())/*鼠標(biāo)右鍵鍵盤(pán)按下*/ {

if(MouseX>190&&MouseX<390&&MouseY>90&&MouseY<290)/*當(dāng)前鼠標(biāo)位置在格子范圍內(nèi)*/ { j=(MouseX-190)/20;/*x坐標(biāo)*/ i=(MouseY-90)/20;/*y坐標(biāo)*/

if(Mine[i][j].flag==0&&Mine[i][j].num!=0)/*本來(lái)沒(méi)紅旗現(xiàn)在顯示紅旗*/ { DrawRedflag(i,j);Mine[i][j].flag=1;} else if(Mine[i][j].flag==1)/*有紅旗標(biāo)志再按右鍵就紅旗消失*/ { DrawEmpty(i,j,0,8);Mine[i][j].flag=0;} } delay(1000000);delay(1000000);delay(1000000);delay(1000000);delay(1000000);} } }

第三篇:數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告(報(bào)告+C語(yǔ)言源代碼)

目錄

前言..................................................................................................................2 概要設(shè)計(jì)..................................................................................................................3 1.1 數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)...........................................................................................3 2.1 算法設(shè)計(jì)...................................................................................................3 2.1.1 建立鏈表的算法..............................................................................3 2.1.2 鏈表插入一個(gè)元素的算法..............................................................3 2.1.3 鏈表刪除一個(gè)元素的算法..............................................................3 3.1 ADT描述..................................................................................................4

4.1

詳細(xì)設(shè)計(jì)…………………………………………… ……………………………… 4

4.1.1

數(shù)據(jù)存儲(chǔ)結(jié)構(gòu)……………………………… ……………………………… 4.4.1.2

主要偽代碼…… …………………… ……………………………………… 4 軟件測(cè)試..................................................................................................................7 心得體會(huì)................................................................................................................11 源代碼...................................................................................................................12 參考文獻(xiàn)………………………………………………………………………...21

前言

數(shù)據(jù)結(jié)構(gòu)是計(jì)算機(jī)程序設(shè)計(jì)的重要理論技術(shù)基礎(chǔ),它不僅是計(jì)算機(jī)學(xué)科的核心課程,而且已經(jīng)成為其他理工專(zhuān)業(yè)的熱門(mén)選修課。

隨著計(jì)算機(jī)科學(xué)的技術(shù)和發(fā)展,計(jì)算機(jī)的功能和運(yùn)算速度不斷地提高,其應(yīng)用于信息處理的范圍日益擴(kuò)大。與之相應(yīng)的,計(jì)算機(jī)的加工處理對(duì)象也從簡(jiǎn)單的數(shù)據(jù)發(fā)展到一般的符號(hào),進(jìn)而發(fā)展到更復(fù)雜的數(shù)據(jù)結(jié)構(gòu)。數(shù)據(jù)結(jié)構(gòu)是計(jì)算機(jī)程序設(shè)計(jì)的重要理論技術(shù)基礎(chǔ),數(shù)據(jù)結(jié)構(gòu)的表示和操作都涉及到算法,如何描述數(shù)據(jù)的結(jié)構(gòu)和討論有關(guān)的算法,又涉及到程序設(shè)計(jì)語(yǔ)言。因此,它不僅是計(jì)算機(jī)學(xué)科的核心課程,而且已經(jīng)成為其他理工專(zhuān)業(yè)的熱門(mén)選修課。我們通過(guò)對(duì)這門(mén)基礎(chǔ)課程的學(xué)習(xí),要學(xué)會(huì)分析研究計(jì)算機(jī)加工的數(shù)據(jù)結(jié)構(gòu)的特性,以便為應(yīng)用涉及的數(shù)據(jù)選擇適合的邏輯結(jié)構(gòu),儲(chǔ)存結(jié)構(gòu)及其相應(yīng)的算法,并初步掌握算法時(shí)間分析和空間分析的技術(shù)。通過(guò)實(shí)際操作去了解數(shù)據(jù)結(jié)構(gòu)原理,練習(xí)編寫(xiě)代碼的能力,以及抽象能力。

從課程性質(zhì)上講,“數(shù)據(jù)結(jié)構(gòu)”是一門(mén)專(zhuān)業(yè)技術(shù)基礎(chǔ)課。它的要求是學(xué)會(huì)分析研究計(jì)算機(jī)加工的數(shù)據(jù)結(jié)構(gòu)的特性,以便為應(yīng)用涉及的數(shù)據(jù)選擇適當(dāng)?shù)倪壿嫿Y(jié)構(gòu),存儲(chǔ)結(jié)構(gòu)及相應(yīng)的算法,并初步掌握算法的時(shí)間分析和空間分析的技術(shù)。另一方面,數(shù)據(jù)結(jié)構(gòu)的學(xué)習(xí)過(guò)程也是復(fù)雜程序設(shè)計(jì)的訓(xùn)練過(guò)程,要求編寫(xiě)的程序結(jié)構(gòu)清楚和正確易讀,符合軟件工程的規(guī)范。

概要設(shè)計(jì)

1.1 數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)

采用鏈?zhǔn)絻?chǔ)存結(jié)構(gòu)。typedef struct LNode{ ElemType data;struct LNode *next;}LNode,*LinkList;2.1 算法設(shè)計(jì)

2.1.1 建立鏈表的算法

(1)算法思想分析

首先從表尾到表頭逆向建立單鏈表,然后再建立的單鏈表基礎(chǔ)上進(jìn)行對(duì)鏈表上的元素進(jìn)行查詢(xún),刪除,插入的操作。(2)要點(diǎn)描述

首先建立一個(gè)帶頭結(jié)點(diǎn)的單鏈表,通過(guò)申請(qǐng)內(nèi)存,先建立一個(gè)空鏈表。然后結(jié)點(diǎn)的插入,建立一個(gè)有多個(gè)結(jié)點(diǎn)的鏈表。在進(jìn)行查詢(xún)等操作。(3)時(shí)間和空間復(fù)雜度分析

程序的時(shí)間復(fù)雜度為O(n)。

2.1.2 鏈表插入一個(gè)元素的算法

(1)算法思想分析

要生成一個(gè)新數(shù)據(jù)域?yàn)閄的結(jié)點(diǎn),然后插入在單鏈表中。(2)要點(diǎn)描述

在鏈表中插入結(jié)點(diǎn)只需要修改指針。若要在第 i 個(gè)結(jié)點(diǎn)之前插入元素,修改的是第 i-1 個(gè)結(jié)點(diǎn)的指針。

(3)時(shí)間和空間復(fù)雜度分析

時(shí)間復(fù)雜度O(n)2.1.3 鏈表刪除一個(gè)元素的算法

(1)算法思想分析

要?jiǎng)h除一個(gè)結(jié)點(diǎn),必須修改指針并且釋放空間。(2)要點(diǎn)描述

找到線(xiàn)性表中第i-1個(gè)結(jié)點(diǎn),修改其指向后繼的指針。

(3)時(shí)間和空間復(fù)雜度分析

時(shí)間復(fù)雜度O(n)

3.1 ADT描述

ADT LinkList{

數(shù)據(jù)對(duì)象:D={ e | e∈LNode }

數(shù)據(jù)關(guān)系:R1={ | e∈LNode ,e >0}

基本操作:

GreateList_L(&L, n)

操作結(jié)果:構(gòu)造了一個(gè)長(zhǎng)為n的數(shù)據(jù)鏈表

ListDelete_L(&L, i, &e)

初始條件:鏈表L已存在而且非空

操作結(jié)果:刪除L的第i個(gè)數(shù)據(jù),并且用e返回其值

ListInsert_L(&L, i, e)

初始條件:鏈表L已存在

操作結(jié)果: 在L的第i個(gè)位置插入數(shù)據(jù)e

GetElem(L, i, e)

初始條件:鏈表L已存在

操作結(jié)果:用e返回L中的第i個(gè)數(shù)據(jù) }ADT LinkList

4.1

詳細(xì)設(shè)計(jì) 4.1.1數(shù)據(jù)存儲(chǔ)結(jié)構(gòu)設(shè)計(jì)

采用單鏈?zhǔn)骄€(xiàn)性表實(shí)現(xiàn)

4.1.2

主要偽代碼

Status GetElem(LinkList L, int i, ElemType *e){ int j=0;int d;LinkList p = L;while(p&&jnext;j++;

} if(!p || j > i)return ERROR;printf(“您要查詢(xún)的元素是:n”);d=p->data;printf(“%d”,d);printf(“n”);}

void InitList(LinkList *L){ *L =(LinkList)malloc(sizeof(struct LNode));if(!*L)exit(OVERFLOW);(*L)->next = NULL;}

Status ListInsert(LinkList L, int i, ElemType e){ int j = 0;LinkList p = L, s;while(p && j < i-1){ p = p->next;j++;} if(!p|| j > i-1)return ERROR;s =(LinkList)malloc(sizeof(struct LNode));s->data = e;s->next = p->next;p->next = s;return OK;}

Status ListDelete(LinkList L, int i, ElemType *e){ int j = 0;LinkList p = L, q;while(p->next && j < i-1){ p = p->next;

j++;} if(!p->next || j > i-1)return ERROR;q = p->next;p->next = q->next;*e = q->data;free(q);return OK;}

void ListTraverse(LinkList L, void(*vi)(ElemType)){ LinkList p = L->next;while(p){ vi(p->data);p = p->next;} printf(“n”);}

void ListPrint(LinkList L){ LinkList p = L->next;while(p){ printf(“%d ”, p->data);p = p->next;} printf(“n”);}

void printInt(int data){ printf(“%d ”, data);}.軟件測(cè)試

圖一(主界面)

圖二(插入學(xué)生信息)

圖三(顯示所有學(xué)生信息)

圖四(查詢(xún)個(gè)人信息)

圖五(統(tǒng)計(jì)信息)

圖六(修改信息)

圖七(保存數(shù)據(jù))

圖八(刪除信息)

心得體會(huì)

通過(guò)本程序的設(shè)計(jì),我對(duì)數(shù)據(jù)結(jié)構(gòu)作了以下總結(jié):要解決一道程序題必須先要認(rèn)真捕捉改程序中的有用信息,找出解決方法。先規(guī)劃好,程序需要什么樣的數(shù)據(jù)結(jié)構(gòu),什么函數(shù),對(duì)程序有什么要求。然后從整體把握對(duì)程序設(shè)計(jì)進(jìn)行分工,相應(yīng)地把程序分成若干模塊,具體實(shí)現(xiàn)各部分實(shí)行相應(yīng)的功能。一個(gè)程序要順利地進(jìn)行設(shè)計(jì),一是要對(duì)程序的功能有全面的了解,如果漏了某些部分,都會(huì)使得這個(gè)程序調(diào)試不出來(lái)或者是令該程序沒(méi)有達(dá)到預(yù)想的效果。其次,在程序的編譯中,必須注重程序設(shè)計(jì)過(guò)程中的細(xì)節(jié),像單鏈表的程序,就要理解鏈表的概念,理解鏈表的數(shù)據(jù)特點(diǎn),要清楚知道數(shù)據(jù)域和指針域的作用,否則,很容易會(huì)浪費(fèi)大量時(shí)間在檢測(cè)錯(cuò)誤上面。要說(shuō)到解題的思考方向,如果要總結(jié)成規(guī)律,我認(rèn)為要靈活的進(jìn)行方法的設(shè)計(jì),通過(guò)不同的方法來(lái)實(shí)現(xiàn)不同的功能,如通過(guò)結(jié)點(diǎn)的插入來(lái)實(shí)現(xiàn)鏈表的創(chuàng)建。同時(shí)應(yīng)該注意各種語(yǔ)句的選擇,要先預(yù)想好需要什么樣的語(yǔ)句來(lái)實(shí)現(xiàn)函數(shù)定義,盡量簡(jiǎn)單快捷地完成,避免出錯(cuò)。

要規(guī)范面向?qū)ο蟪绦蛟O(shè)計(jì)師的書(shū)寫(xiě)協(xié)管,在這次課程設(shè)計(jì)中,我們?cè)俅胃惺艿剑?guī)范的程序書(shū)寫(xiě),可以更好的進(jìn)行后期的差錯(cuò)補(bǔ)漏。還應(yīng)該注意各種面向?qū)ο笳Z(yǔ)言語(yǔ)法的運(yùn)用,例如繼承的方法,都要嚴(yán)格按照語(yǔ)法來(lái)進(jìn)行,否則很容易就會(huì)出現(xiàn)錯(cuò)誤,甚至嚴(yán)重影響課程設(shè)計(jì)的進(jìn)度。

源代碼

#include “stdio.h” #include “stdlib.h” #include “string.h” int shoudsave=0;// struct student {

char num[10];//學(xué)號(hào)

char name[20];

char sex[4];

int cgrade;

int mgrade;

int egrade;

int totle;

int ave;

char neartime[10];//最近更新時(shí)間

};

typedef struct node {

struct student data;

struct node *next;}Node,*Link;

int menu(){

char m[3];

int n;

printf(“ ************************歡迎進(jìn)入學(xué)生成績(jī)管理系統(tǒng)******************************nn”);

printf(“t歡迎使用本學(xué)生管理系統(tǒng),本系統(tǒng)將為您提供歷史學(xué)生信息查詢(xún),學(xué)生成績(jī)信息管理功能。n”);

printf(“********************************************************************************”);

printf(“t1輸入學(xué)生資料ttttt2刪除學(xué)生資料n”);

printf(“t3查詢(xún)學(xué)生資料ttttt4修改學(xué)生資料n”);

printf(“t5顯示學(xué)生資料ttttt6統(tǒng)計(jì)學(xué)生成績(jī)n”);

printf(“t7保存學(xué)生資料n”);

printf(“ttplease choose a operation(1-7):n”);

printf(“***********************************************************************

*********n”);

scanf(“%s”,m);

n=atoi(m);

return(n);}

void printstart(){

printf(“---------n”);}

void Wrong(){

printf(“n=====>提示:輸入錯(cuò)誤!n”);}

void Nofind(){

printf(“n=====>提示:沒(méi)有找到該學(xué)生!n”);}

void printc()// 本函數(shù)用于輸出中文

{

printf(“學(xué)號(hào)t 姓名

性別

英語(yǔ)成績(jī) 數(shù)據(jù)庫(kù)成績(jī) 數(shù)據(jù)結(jié)構(gòu)成績(jī)

總分平均分n”);}

void printe(Node *p)//本函數(shù)用于輸出英文

{

printf(“%-12s%stt%st%dtt%dt%dt%dt %dn”,p->data.num,p->data.name,p->data.sex,p->data.egrade,p->data.mgrade,p->data.cgrade,p->data.totle,p->data.ave);}

Node* Locate(Link l,char findmess[],char nameornum[])//該函數(shù)用于定位連表中符合要求的接點(diǎn),并返回該指針

{

Node *r;

if(strcmp(nameornum,“num”)==0)//按學(xué)號(hào)查詢(xún)

{

r=l->next;

while(r!=NULL)

{

if(strcmp(r->data.num,findmess)==0)

return r;

r=r->next;

}

}

else if(strcmp(nameornum,“name”)==0)//按姓名查詢(xún)

{

r=l->next;

while(r!=NULL)

{

if(strcmp(r->data.name,findmess)==0)

return r;

r=r->next;

}

}

return 0;}

void Add(Link l)//增加學(xué)生

{

Node *p,*r,*s;

char num[10];

r=l;

s=l->next;

while(r->next!=NULL)

r=r->next;//將指針置于最末尾

while(1)

{

printf(“請(qǐng)你輸入學(xué)號(hào)(以'0'返回上一級(jí)菜單:)”);

scanf(“%s”,num);

if(strcmp(num,“0”)==0)

break;

while(s)

{

if(strcmp(s->data.num,num)==0)

{

printf(“=====>提示:學(xué)號(hào)為'%s'的學(xué)生已經(jīng)存在,若要修改請(qǐng)你選擇'4 修改'!n”,num);

printstart();

printc();

printe(s);

printstart();

printf(“n”);

return;

}

s=s->next;

}

p=(Node *)malloc(sizeof(Node));

strcpy(p->data.num,num);

printf(“請(qǐng)你輸入姓名:”);

scanf(“%s”,p->data.name);

getchar();

printf(“請(qǐng)你輸入性別:”);

scanf(“%s”,p->data.sex);

getchar();

printf(“請(qǐng)你輸入數(shù)據(jù)結(jié)構(gòu)成績(jī):”);

scanf(“%d”,&p->data.cgrade);

getchar();

printf(“請(qǐng)你輸入數(shù)據(jù)庫(kù)成績(jī):”);

scanf(“%d”,&p->data.mgrade);

getchar();

printf(“請(qǐng)你輸入英語(yǔ)成績(jī):”);

scanf(“%d”,&p->data.egrade);

getchar();

p->data.totle=p->data.egrade+p->data.cgrade+p->data.mgrade;

p->data.ave=p->data.totle / 3;

//信息輸入已經(jīng)完成p->next=NULL;

r->next=p;

r=p;

shoudsave=1;

} }

void Qur(Link l)//查詢(xún)學(xué)生

{

char findmess[20];

Node *p;

if(!l->next)

{

printf(“n=====>提示:沒(méi)有資料可以查詢(xún)!n”);

return;

}

printf(“請(qǐng)你輸入要查找的學(xué)號(hào):”);

scanf(“%s”,findmess);

p=Locate(l,findmess,“num”);

if(p)

{

printf(“tttt查找結(jié)果n”);

printstart();

printc();

printe(p);

printstart();

}

else

Nofind();}

void Del(Link l)//刪除

{

Node *p,*r;

char findmess[20];

if(!l->next)

{

printf(“n=====>提示:沒(méi)有資料可以刪除!n”);

return;

}

printf(“n=====>確定進(jìn)行刪除操作請(qǐng)按 1,按其他按鍵退出該操作nnnn”);

if(menu()==1)

{

printf(“請(qǐng)你輸入要?jiǎng)h除的學(xué)號(hào):”);

scanf(“%s”,findmess);

p=Locate(l,findmess,“num”);

if(p)

{

r=l;

while(r->next!=p)

r=r->next;

r->next=p->next;

free(p);

printf(“n=====>提示:該學(xué)生已經(jīng)成功刪除!n”);

shoudsave=1;

}

else

Nofind();

}

else

exit;}

void Modify(Link l)//修改函數(shù) {

Node *p;

char findmess[20];

if(!l->next)

{

printf(“n=====>提示:沒(méi)有資料可以修改!n”);

return;

}

printf(“請(qǐng)你輸入要修改的學(xué)生學(xué)號(hào):”);

scanf(“%s”,findmess);

p=Locate(l,findmess,“num”);

if(p)

{

printf(“請(qǐng)你輸入新學(xué)號(hào)(原來(lái)是%s):”,p->data.num);

scanf(“%s”,p->data.num);

printf(“請(qǐng)你輸入新姓名(原來(lái)是%s):”,p->data.name);

scanf(“%s”,p->data.name);

getchar();

printf(“請(qǐng)你輸入新性別(原來(lái)是%s):”,p->data.sex);

scanf(“%s”,p->data.sex);

printf(“請(qǐng)你輸入新的數(shù)據(jù)結(jié)構(gòu)成績(jī)(原來(lái)是%d分):”,p->data.cgrade);

scanf(“%d”,&p->data.cgrade);

getchar();

printf(“請(qǐng)你輸入新的數(shù)據(jù)庫(kù)成績(jī)(原來(lái)是%d分):”,p->data.mgrade);

scanf(“%d”,&p->data.mgrade);

getchar();

printf(“請(qǐng)你輸入新的英語(yǔ)成績(jī)(原來(lái)是%d分):”,p->data.egrade);

scanf(“%d”,&p->data.egrade);

p->data.totle=p->data.egrade+p->data.cgrade+p->data.mgrade;

p->data.ave=p->data.totle/3;

printf(“n=====>提示:資料修改成功!n”);

shoudsave=1;

}

else

Nofind();

}

void Disp(Link l)//顯示函數(shù) {

int count=0;

Node *p;

p=l->next;

if(!p)

{

printf(“n=====>提示:沒(méi)有資料可以顯示!n”);

return;

}

printf(“tttt顯示結(jié)果n”);

printstart();

printc();

printf(“n”);

while(p)

{

printe(p);

p=p->next;

}

printstart();

printf(“n”);}

void Tongji(Link l)//統(tǒng)計(jì)函數(shù) {

Node *pm,*pe,*pc,*pt,*pa;//用于指向分?jǐn)?shù)最高的接點(diǎn)

Node *r=l->next;

if(!r)

{

printf(“n=====>提示:沒(méi)有資料可以統(tǒng)計(jì)!n”);

return;

}

pm=pe=pc=pt=pa=r;

while(r!=NULL)

{

if(r->data.cgrade>=pc->data.cgrade)

pc=r;

if(r->data.mgrade>=pm->data.mgrade)

pm=r;

if(r->data.egrade>=pe->data.egrade)

pe=r;

if(r->data.totle>=pt->data.totle)

pt=r;

if(r->data.ave>=pa->data.ave)

pa=r;

r=r->next;

}

printf(“------------------------------統(tǒng)計(jì)結(jié)果-n”);

printf(“總分最高者:t%s %d分n”,pt->data.name,pt->data.totle);

printf(“平均分最高者:t%s %d分n”,pa->data.name,pa->data.ave);

printf(“英語(yǔ)最高者:t%s %d分n”,pe->data.name,pe->data.egrade);

printf(“數(shù)據(jù)庫(kù)最高者:t%s %d分n”,pm->data.name,pm->data.mgrade);

printf(“數(shù)據(jù)結(jié)構(gòu)最高者:t%s %d分n”,pc->data.name,pc->data.cgrade);

printstart();}

void Save(Link l)//保存函數(shù) {

FILE* fp;

Node *p;

int flag=1,count=0;

fp=fopen(“c:student”,“wb”);

if(fp==NULL)

{

printf(“n=====>提示:重新打開(kāi)文件時(shí)發(fā)生錯(cuò)誤!n”);

exit(1);

}

p=l->next;

while(p)

{

if(fwrite(p,sizeof(Node),1,fp)==1)

{

p=p->next;

count++;

}

else

{

flag=0;

break;

}

}

if(flag)

{

printf(“n=====>提示:文件保存成功.(有%d條記錄已經(jīng)保存.)n”,count);

shoudsave=0;

}

fclose(fp);}

void main(){

Link l;//連表

FILE *fp;//文件指針

char ch;

char jian;

int count=0;

Node *p,*r;

l=(Node*)malloc(sizeof(Node));

l->next=NULL;

r=l;

fp=fopen(“C:student”,“rb”);

if(fp==NULL)

{

fp=fopen(“C:student”,“wb”);

exit(0);

}

printf(“n=====>提示:文件已經(jīng)打開(kāi),正在導(dǎo)入記錄......n”);

while(!feof(fp))

{

p=(Node*)malloc(sizeof(Node));

if(fread(p,sizeof(Node),1,fp))//將文件的內(nèi)容放入接點(diǎn)中

{

p->next=NULL;

r->next=p;

r=p;//將該接點(diǎn)掛入連中

count++;

}

}

fclose(fp);//關(guān)閉文件

printf(“n=====>提示:記錄導(dǎo)入完畢,共導(dǎo)入%d條記錄.n”,count);

for(;;)

{

switch(menu())

{

case 1:Add(l);break;//增加學(xué)生

case 2:Del(l);break;//刪除學(xué)生

case 3:Qur(l);break;//查詢(xún)學(xué)生

case 4:Modify(l);break;//修改學(xué)生

case 5:Disp(l);break;//顯示學(xué)生

case 6:Tongji(l);break;//統(tǒng)計(jì)學(xué)生

case 7:Save(l);break;//保存學(xué)生

default: Wrong();

getchar();

break;

}

}

}

參考文獻(xiàn)

《數(shù)據(jù)結(jié)構(gòu)(C語(yǔ)言版)》----------------清華大學(xué)出版社 嚴(yán)蔚敏 吳偉民 編著 《C語(yǔ)言程序設(shè)計(jì)》------------------------中國(guó)鐵道出版社 丁峻嶺 余堅(jiān) 編著

第四篇:C語(yǔ)言課程設(shè)計(jì)火車(chē)票系統(tǒng)源代碼

#include #include #include //火車(chē)票結(jié)構(gòu)體類(lèi)型// typedef struct Node {int num;

//編號(hào)// char name[20];

//起點(diǎn)和終點(diǎn)// char time[5];

//出發(fā)時(shí)間// int price;

//車(chē)票價(jià)格// int amount;

//剩余數(shù)量// struct Node *next;}Node;//創(chuàng)建鏈表并輸入數(shù)據(jù)// struct Node *creat(){ struct Node *head,*r,*s;

int i=0;

char choice;

head=(struct Node *)malloc(sizeof(struct Node));head->next=NULL;r=head;do {

s=(struct Node *)malloc(sizeof(struct Node));s->next=NULL;printf(“請(qǐng)輸入第%d種火車(chē)票的信息:n”,++i);printf(“請(qǐng)輸入火車(chē)的編號(hào):”);

scanf(“%d”,&s->num);

printf(“起點(diǎn)和終點(diǎn):”);scanf(“%s”,s->name);printf(“出發(fā)時(shí)間:”);scanf(“%s”,s->time);printf(“車(chē)票價(jià)格:”);scanf(“%d”,&s->price);printf(“剩余數(shù)量:”);scanf(“%d”,&s->amount);

r->next=s;

r=s;

printf(“Continue?(Y/N)”);scanf(“%s”,&choice);}while(choice=='Y'||choice=='y');

r->next=NULL;return(head);} //將單鏈表中的信息保存到文件1.txt中// void save(struct Node *h){

struct Node *s;FILE *fp;

char filename[10]=“1.txt”;

fp=fopen(“1.txt”,“wt”);if(fp==NULL){

printf(“n寫(xiě)文件出錯(cuò),按任意鍵退出!”);getchar();exit(1);}

for(s=h->next;s!=NULL;s=s->next)

fprintf(fp,“%d %s %s %d %d n”,s->num,s->name,s->time,s->price,s->amount);

getchar();fclose(fp);} // 從文件1.txt中讀取信息并存入單鏈表中// struct Node *read(){ struct Node *head,*r,*s;FILE *fp;char filename[10]=“zl.txt”;fp=fopen(“1.txt”,“rt”);if(fp==NULL){

printf(“讀文件錯(cuò)誤,按任意鍵退出!”);getchar();exit(1);} head=(struct Node *)malloc(sizeof(struct Node));head->next=NULL;r=head;while(!feof(fp)){

s=(struct Node *)malloc(sizeof(struct Node));fscanf(fp,“%d %s %s %d %d”,&s->num,s->name,s->time,&s->price,&s->amount);

r->next=s;r=s;

} r->next=NULL;fclose(fp);

return head;} //將鏈表中的數(shù)據(jù)輸出// void print(struct Node *h){

struct Node *s;

printf(“n火車(chē)票信息如下:n”);

printf(“~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~n”);printf(“編號(hào)

起點(diǎn)和終點(diǎn)

出發(fā)時(shí)間

車(chē)票價(jià)格

剩余票數(shù):n”);

for(s=h->next;s->next!=NULL;s=s->next){ printf(“ %d

%10s

%5s %10d %6dn”,s->num,s->name,s->time,s->price,s->amount);} } //鏈表查詢(xún)// struct Node * find(struct Node *h){ int i,j;char s[20];printf(“tt

查詢(xún)方法有以下幾種:n”);printf(“tt

1.火車(chē)票編號(hào)n”);printf(“tt

2.起點(diǎn)和終點(diǎn)n”);printf(“tt

3.出發(fā)時(shí)間n”);printf(“tt

4.車(chē)票價(jià)格n”);printf(“tt

5.剩余票數(shù)n”);printf(“請(qǐng)輸入您要查詢(xún)的方法的序號(hào):”);scanf(“%d”,&i);switch(i){ case 1:printf(“請(qǐng)輸入你要查詢(xún)火車(chē)票的編號(hào):”);scanf(“%d”,&j);

while(h->next!=NULL)

{

h=h->next;

if(h->num==j)return h;

}

return NULL;break;case 2:printf(“請(qǐng)輸入您要查詢(xún)火車(chē)票的起點(diǎn)和終點(diǎn):”);scanf(“%s”,s);while(h->next!=NULL){

h=h->next;if(strcmp(h->name,s)==0)

return h;

} return NULL;break;case 3:printf(“請(qǐng)輸入您要查詢(xún)火車(chē)票的時(shí)間:”);

scanf(“%s”,s);

while(h->next!=NULL)

{

h=h->next;

if(strcmp(h->time,s)==0)

return h;

}

return NULL;

break;case 4:printf(“請(qǐng)輸入你要查詢(xún)火車(chē)票的價(jià)格 :”);scanf(“%d”,&j);

while(h->next!=NULL)

{

h=h->next;

if(h->price==j)

return h;

}

return NULL;

break;case 5:printf(“請(qǐng)輸入你要查詢(xún)火車(chē)票的剩余票數(shù):”);scanf(“%d”,&j);

while(h->next!=NULL)

{

h=h->next;

if(h->amount==j)

return h;

} return NULL;

break;} } //修改信息// change(struct Node *h,int k){ int j;struct Node *p;p=find(h);printf(“------------n”);printf(“t

您要修改哪一項(xiàng)?n”);printf(“t

1.火車(chē)編號(hào)n”);printf(“t

2.起點(diǎn)和終點(diǎn)n”);printf(“t

3.出發(fā)時(shí)間n”);printf(“t

4.車(chē)票價(jià)格n”);

printf(“t

5.剩余票數(shù)n”);printf(“t

0.退出系統(tǒng)n”);

printf(“------------n”);printf(“請(qǐng)輸入您要修改項(xiàng)的編號(hào):”);scanf(“%d”,&j);switch(j)

{ case 1:

printf(“修改后的火車(chē)編號(hào):”);

scanf(“%d”,&p->num);

break;

case 2:

printf(“修改后的起點(diǎn)和終點(diǎn):”);

scanf(“%s”,p->name);

break;

case 3:

printf(“修改后的出發(fā)時(shí)間:”);

scanf(“%s”,p->time);

break;

case 4:

printf(“修改后的車(chē)票價(jià)格:”);

scanf(“%d”,&p->price);

break;

case 5:

printf(“修改后的剩余票數(shù):”);

scanf(“%d”,&p->amount);

break;

case 0:break;} } //刪除信息// delete(struct Node *h){ struct Node *p;

int j;

printf(“請(qǐng)輸入您要?jiǎng)h除的火車(chē)票的編號(hào):”);scanf(“%d”,&j);p=h->next;

if(p==NULL)

return 0;while(p!=NULL){ if(p->num==j){

h->next=p->next;

free(p);

return 1;} h=p;p=p->next;

} return 0;} //添加信息// void append(){

struct Node *p;

FILE *fp;

fp=fopen(“1.txt”,“at+”);

if(fp==NULL)

{

printf(“寫(xiě)文件出錯(cuò),按任意鍵返回.n”);getchar();exit(1);

}

printf(“請(qǐng)輸入要添加的火車(chē)票的信息:火車(chē)編號(hào),起點(diǎn)和終點(diǎn),出發(fā)時(shí)間,車(chē)票價(jià)格,剩余票數(shù):n”);scanf(“%d%s%s%d%d”,&p->num,p->name,p->time,&p->price,&p->amount);fprintf(fp,“%d %s %s %d %dn”,p->num,p->name,p->time,p->price,p->amount);getchar();fclose(fp);} //數(shù)據(jù)的統(tǒng)計(jì)// void count(struct Node *h){ struct Node *s;s=h;int i,j,k,n=0;printf(“*****************************************************************************n”);

printf(“tt

請(qǐng)選擇您要統(tǒng)計(jì)項(xiàng)目的序號(hào):n”);

printf(“tt

1.車(chē)票價(jià)格n”);

printf(“tt

2.剩余票數(shù)n”);printf(“tt

0.退出界面n”);

scanf(“%d”,&i);switch(i)

{

case 1:

printf(“請(qǐng)輸入您要統(tǒng)計(jì)車(chē)票的價(jià)格的標(biāo)準(zhǔn):”);

scanf(“%d”,&j);

printf(“tt

請(qǐng)選擇低于或高于標(biāo)準(zhǔn):n”);

printf(“tt

1.價(jià)格低于%d的個(gè)數(shù)n”,j);

printf(“tt

2.價(jià)格高于%d的個(gè)數(shù)n”,j);

scanf(“%d”,&k);

if(k==1)

{

for(s=h->next;s->next!=NULL;s=s->next)

if(s->price

n++;

printf(“車(chē)票價(jià)格低于%d的個(gè)數(shù)有%d個(gè).n”,j,n);

}

else

{

for(s=h->next;s->next!=NULL;s=s->next)

if(s->price>j)

n++;

printf(“車(chē)票價(jià)格低于%d的個(gè)數(shù)有%d個(gè).n”,j,n);

}

break;

case 2:

printf(“請(qǐng)輸入您要統(tǒng)計(jì)剩余票數(shù)的數(shù)量:”);

scanf(“%d”,&j);

printf(“tt

請(qǐng)選擇低于或高于所輸票數(shù):n”);

printf(“tt

1.票數(shù)低于%d的個(gè)數(shù)n”,j);

printf(“tt

2.票數(shù)高于%d的個(gè)數(shù)n”,j);

scanf(“%d”,&k);

if(k==1)

{

for(s=h->next;s->next!=NULL;s=s->next)

if(s->amount

n++;

printf(“剩余票數(shù)低于%d的個(gè)數(shù)有%d個(gè).n”,j,n);

}

else

{

for(s=h->next;s->next!=NULL;s=s->next)

if(s->amount>j)

n++;

printf(“剩余票數(shù)高于%d的個(gè)數(shù)有%d個(gè).n”,j,n);

}

break;

case 0:break;

} } //保存用戶(hù)和密碼到文件2.txt中// void save_user(){

char file[10]=“2.txt”;FILE *fp;char name[20];char pwd[10];fp=fopen(“2.txt”,“at+”);if(fp==NULL){ printf(“n寫(xiě)文件出錯(cuò),按任意鍵退出.n”);

getchar();exit(1);} printf(“請(qǐng)輸入用戶(hù)名:”);

scanf(“%s”,name);printf(“請(qǐng)輸入密碼:”);

scanf(“%s”,pwd);

fprintf(fp,“%s %sn”,name,pwd);

getchar();

fclose(fp);

printf(“用戶(hù)注冊(cè)成功!n”);} //檢驗(yàn)用戶(hù)和密碼是否匹配// int check(char *name,char *pwd){ char name1[20];char pwd1[10];FILE *fp;char file[10]=“2.txt”;if((fp=fopen(“2.txt”,“rt”))==NULL){

printf(“讀文件出錯(cuò),按任意鍵退出!n”);

getchar();

exit(1);}

while(!feof(fp)){

fscanf(fp,“%s %s”,name1,pwd1);

if(strcmp(name1,name)==0&&strcmp(pwd1,pwd)==0)

return 1;} return 0;} //數(shù)據(jù)排序// void sort(struct Node *h){ struct Node *s,*p,*m,*n;int t,t1,t2,t3;char s1[20];char s2[10];

printf(“車(chē)票價(jià)格由小到大排序如下:n”);for(s=h->next;s->next!=NULL;s=s->next)for(p=s->next;p->next!=NULL;p=p->next)

if(s->price>p->price)

{

t1=s->num;s->num=p->num;p->num=t1;

t2=s->price;s->price=p->price;p->price=t2;

t3=s->amount;s->amount=p->amount;p->amount=t3;

strcpy(s1,s->name);strcpy(s->name,p->name);strcpy(p->name,s1);

strcpy(s2,s->time);strcpy(s->time,p->time);strcpy(p->time,s2);

}

print(h);printf(“nn剩余車(chē)票數(shù)量由多到少排序如下:n”);for(s=h->next;s->next!=NULL;s=s->next)

for(p=s->next;p->next!=NULL;p=p->next)

if(s->amount

amount)

{

t1=s->num;s->num=p->num;p->num=t1;

t2=s->price;s->price=p->price;p->price=t2;

t3=s->amount;s->amount=p->amount;p->amount=t3;

strcpy(s1,s->name);strcpy(s->name,p->name);strcpy(p->name,s1);

strcpy(s2,s->time);strcpy(s->time,p->time);strcpy(p->time,s2);

} print(h);} void main(){ struct Node *head,*p;int i,j,k;head=(struct Node *)malloc(sizeof(struct Node));head->next=NULL;char name[20];char pwd[10];printf(“n***************歡迎進(jìn)入火車(chē)票管理系統(tǒng)******************n”);printf(“tt 1.用戶(hù)登錄n”);printf(“tt 2.用戶(hù)注冊(cè)n”);printf(“tt 0.退出系統(tǒng) n”);printf(“請(qǐng)輸入所選序號(hào):”);scanf(“%d”,&k);

switch(k){ case 1: printf(“請(qǐng)輸入用戶(hù)名:”);

scanf(“%s”,name);

printf(“請(qǐng)輸入密碼:”);

scanf(“%s”,pwd);

if(check(name,pwd))

{

printf(“密碼正確.n”);

do

{

printf(“nntt*********************歡迎進(jìn)入火車(chē)票管理系統(tǒng)***********************n”);

printf(“tt

1.錄入火車(chē)票信息tt

2.添加火車(chē)票信息n”);

printf(“tt

3.修改火車(chē)票信息tt

4.刪除火車(chē)票信息n”);

printf(“tt

5.打印火車(chē)票信息tt

6.查詢(xún)火車(chē)票信息n”);

printf(“tt

7.統(tǒng)計(jì)火車(chē)票信息tt

8.火車(chē)票銷(xiāo)售排行n”);

printf(“tt

0.退出系統(tǒng)n”);

printf(“請(qǐng)輸入您要進(jìn)入菜單的序號(hào)(0-8):”);

scanf(“%d”,&i);

switch(i)

{

case 1:

printf(“請(qǐng)錄入火車(chē)票信息nn”);

head=creat();

save(head);

head=read();

break;

case 2:

append();

break;

case 3:

printf(“請(qǐng)輸入您要修改的火車(chē)票的編號(hào):”);

scanf(“%d”,&j);

change(head,j);

save(head);

break;

case 4:

head=read();

if(delete(head))

{

printf(“已正確刪除!n”);

save(head);

}

else

printf(“要?jiǎng)h除的結(jié)點(diǎn)不存在!n”);

break;

case 5:

head=read();

print(head);

break;

case 6:

printf(“請(qǐng)輸入您要查詢(xún)火車(chē)票的編號(hào)(以0結(jié)束):”);

scanf(“%d”,&j);

{

p=find(head);

printf(“編號(hào)

起點(diǎn)和終點(diǎn)

出發(fā)時(shí)間

車(chē)票價(jià)格

剩余票數(shù):n”);

printf(“%d

%10s

%5s %10d %6dn”,p->num,p->name,p->time,p->price,p->amount);

printf(“請(qǐng)繼續(xù)輸入序號(hào)(以0結(jié)束):”);

scanf(“%d”,&j);

}

break;

case 7: head=read();count(head);break;

case 8: sort(head);break;

case 0: printf(“************************用!*****************************n”);break;

}

}while(i!=0);

}

else

printf(“密碼錯(cuò)誤或用戶(hù)名不存在.n”);

break;case 2:save_user();break;case 0:break;}

使

第五篇:C語(yǔ)言課程設(shè)計(jì)——飛機(jī)訂票系統(tǒng)源代碼

#include //標(biāo)準(zhǔn)輸入、輸出頭文件 #include //包含字符串函數(shù)處理頭文件 #include

//包含access函數(shù)的頭文件 #define N 9999

//定義最多的航班數(shù)

#define PRINT “%dtt%stt%stt星期%stt%dn ”,s[i].num,s[i].start,s[i].over,s[i].time,s[i].count

//宏定義輸出格式

struct air

//定義結(jié)構(gòu)體數(shù)組 { int num;

//定義航班號(hào)

char start[20];//航班起始站

char over[20];//終點(diǎn)站

char time[10];//飛行時(shí)間

int count;

//機(jī)票數(shù)量 }s[N];

int i,m=0;

//定義全局變量 char ii[10];

void add();//函數(shù)聲明增加航班信息函數(shù) void print();

//顯示航班信息 void search();//查找航班信息 void dingpiao();//訂票業(yè)務(wù) void tuipiao();//退票 void read();//讀取文件

void save();//保存文件 void output();//輸出格式 void paixu();//航班排序 void chushihua();//系統(tǒng)初始化 void build();//建立數(shù)據(jù)文件 void paixu1();//按航班號(hào)從小到大排序 void paixu2();//從大到小

void main()//主函數(shù) { int j;

chushihua();//系統(tǒng)初始化判斷是否存在原始數(shù)據(jù)文件

printf(“

歡迎使用飛機(jī)訂票系統(tǒng)n”);//打印出系統(tǒng)主界面

do {

printf(“================================== ”);

printf(“1.增加航班信息n”

“t2.瀏覽航班信息n”

“tt3.查找航班信息(按航班號(hào))tt╮(╯_╰)╭n”

“ttt4.航班排序(按航班號(hào))n”

“tttt5.訂票業(yè)務(wù)n”

“to(︶︿︶)ottt6.退票業(yè)務(wù)n”

“tttttt0.退出n”);printf(“================================== ”);

printf(“請(qǐng)?jiān)?-6中選擇以回車(chē)鍵結(jié)束: ”);scanf(“%d”,&j);switch(j){

case 1: add();//調(diào)用增加航班函數(shù)

break;

case 2:print();//調(diào)用顯示模塊

break;

case 3:search();//調(diào)用查找模塊

break;

case 4:paixu();//調(diào)用排序函數(shù)

break;

case 5:dingpiao();//調(diào)用訂票模塊

break;

case 6:tuipiao();//調(diào)用退票模塊

break;

case 0:

//退出系統(tǒng)

save();

printf(“謝謝使用,再見(jiàn)!”);

break;} }while(j!=0);//判斷是否調(diào)用其他函數(shù)

}

void chushihua()//定義系統(tǒng)初始化函數(shù) { if(access(“hangban.dat”,0)){

build();} else

read();} void build()//定義建立數(shù)據(jù)文件函數(shù) { FILE *fp;//定義文件指針

if((fp=fopen(“hangban.dat”,“wb”))==NULL)//打開(kāi)文件并判定是否出錯(cuò)

{

printf(“創(chuàng)建文件失敗!”);//打印出錯(cuò)提示

getchar();

return;} printf(“請(qǐng)依次輸入航班信息(以回車(chē)鍵結(jié)束):n”);

//打印提示信息

printf(“------------n”);for(i=0;i

printf(“請(qǐng)輸入航班號(hào): ”);

scanf(“%d”,&s[i].num);//輸入航班號(hào)

printf(“請(qǐng)輸入起始站: ”);

scanf(“%s”,s[i].start);//輸入起始站

printf(“請(qǐng)輸入終點(diǎn)站: ”);

scanf(“%s”,s[i].over);//輸入終點(diǎn)站

printf(“請(qǐng)輸入時(shí)間(星期幾): ”);

scanf(“%s”,s[i].time);//輸入時(shí)間

printf(“請(qǐng)輸入機(jī)票數(shù): ”);

scanf(“%d”,&s[i].count);//輸入機(jī)票數(shù)

fwrite(&s[i],sizeof(struct air),1,fp);

m++;

printf(“添加完畢,是否繼續(xù)添加?請(qǐng)鍵入y或n以回車(chē)鍵結(jié)束:”);

scanf(“%s”,ii);

if(strcmp(ii,“y”)!=0)

//判斷是否繼續(xù)添加航班信息

{

fclose(fp);

//關(guān)閉文件

return;

} } }

void read()

//定義讀取文件函數(shù) { FILE *fp;if((fp=fopen(“hangban.dat”,“r”))==NULL){

printf(“創(chuàng)建文件失敗!”);

getchar();

return;} i=0;while(!feof(fp)){

fread(&s[i],sizeof(struct air),1,fp);//逐塊讀取數(shù)據(jù)

i++;

m++;//計(jì)算存在航班數(shù)

} m--;fclose(fp);}

void save()//定義保存函數(shù) { FILE *fp;if((fp=fopen(“hangban.dat”,“wb”))==NULL)

{

printf(“創(chuàng)建文件失敗!”);

getchar();

return;} for(i=0;i

//逐塊保存數(shù)據(jù)

fwrite(&s[i],sizeof(struct air),1,fp);fclose(fp);}

void add()//定義增加航班信息函數(shù) { do{

printf(“請(qǐng)依次輸入您要增加的航班信息(以回車(chē)鍵結(jié)束): n”);

//打印提示信息

printf(“------------n”);

printf(“請(qǐng)輸入航班號(hào): ”);

scanf(“%d”,&s[m].num);//讀取航班號(hào)

printf(“請(qǐng)輸入起始站: ”);

scanf(“%s”,s[m].start);//讀取起始站

printf(“請(qǐng)輸入終點(diǎn)站: ”);

scanf(“%s”,s[m].over);//讀取終點(diǎn)站

printf(“請(qǐng)輸入時(shí)間: ”);

scanf(“%s”,s[m].time);//讀取時(shí)間

printf(“請(qǐng)輸入機(jī)票數(shù): ”);

scanf(“%d”,&s[m].count);//讀取機(jī)票數(shù)

m++;

printf(“添加完畢,是否繼續(xù)添加?請(qǐng)鍵入y或n以回車(chē)鍵結(jié)束:”);

scanf(“%s”,ii);}while(!strcmp(ii,“y”));//判斷是否繼續(xù)添加 }

void output()//定義輸出格式函數(shù) { printf(“航班號(hào)tt起始站tt終點(diǎn)站tt時(shí)間tt機(jī)票數(shù)n”);//信息標(biāo)題

for(i=0;i

printf(PRINT);//打印出信息

}

void print()//定義顯示航班信息函數(shù) { printf(“n目前我們有如下航班:n”);output();

//調(diào)用輸出格式函數(shù)

printf(“n請(qǐng)按回車(chē)鍵返回上層菜單 ”);getchar();getchar();}

void search()//定義查詢(xún)函數(shù) { int n;

do {

printf(“n請(qǐng)輸入航班號(hào): ”);

scanf(“%d”,&n);//輸入查詢(xún)的航班號(hào)

for(i=0;i

{

if(s[i].num==n)//按航班號(hào)判定輸出條件

{

printf(“n您所查找的航班信息為:n ”);

printf(“航班號(hào)tt起始站tt終點(diǎn)站tt時(shí)間tt機(jī)票數(shù) nn”);

printf(PRINT);//顯示信息

printf(“n查詢(xún)完畢,按回車(chē)鍵繼續(xù)”);

getchar();

getchar();

return;

} } printf(“n對(duì)不起,沒(méi)有您需要的信息!n ”);printf(“是否重新查找?請(qǐng)鍵入y或n以回車(chē)鍵結(jié)束 ”);scanf(“%s”,ii);}while(!strcmp(ii,“y”));//判定是否重新查找 }

void dingpiao()//定義訂票業(yè)務(wù)函數(shù) { int n;char a[10]=“y”;do {

search();//調(diào)用查詢(xún)模塊

if(!strcmp(ii,“n”))

{

printf(“對(duì)不起!沒(méi)有找到您所需要的航班,所以不能訂票。n”);//未查找到所需航班

printf(“n請(qǐng)按回車(chē)鍵返回上層菜單 ”);

getchar();

getchar();

strcpy(ii,“n”);

break;

}

do

{

printf(“請(qǐng)輸入您要訂的機(jī)票數(shù)(以回車(chē)鍵結(jié)束): ”);

scanf(“%d”,&n);//輸入所訂機(jī)票數(shù)

if(n<=0)

//判定機(jī)票數(shù)是否出錯(cuò)

{

printf(“輸入錯(cuò)誤!至少需訂1張機(jī)票。n”);

}

else if(s[i].count==0)//判定機(jī)票是否售完

{

printf(“對(duì)不起,你所選擇的航班的機(jī)票已售完!n”);

break;

}

else if(s[i].count!=0&&s[i].count>=n)//判定機(jī)票數(shù)是否大于等于訂票數(shù)

{

s[i].count=s[i].count-n;

printf(“訂票成功!”);

break;

}

else if(s[i].count

{

printf(“對(duì)不起,你所選擇的航班只剩 %d張機(jī)票n”, s[i].count);

printf(“是否需要重新輸入機(jī)票數(shù)?請(qǐng)輸入y或n以回車(chē)鍵結(jié)束: ”);//判定是否重新輸入訂票數(shù)

scanf(“%s”,a);

}

}while(!strcmp(a,“y”));

printf(“是否需要訂其他航班的機(jī)票?請(qǐng)輸入y或n以回車(chē)鍵結(jié)束: ”);

scanf(“%s”,a);}while(!strcmp(a,“y”));//判定是否繼續(xù)訂票 }

void tuipiao()//定義退票函數(shù) { int n;char a[10];do {

search();//調(diào)用查詢(xún)函數(shù)

if(!strcmp(ii,“n”))

{

printf(“對(duì)不起!沒(méi)有找到您所需要的航班,所以不能退票。n”);

printf(“n請(qǐng)按回車(chē)鍵返回上層菜單 ”);

getchar();

getchar();

strcpy(ii,“n”);

break;

}

printf(“請(qǐng)輸入您要退的機(jī)票數(shù)目: ”);

scanf(“%d”,&n);//輸入所退票數(shù)

if(n<=0)

//判定票數(shù)是否有效

printf(“輸入錯(cuò)誤!至少需退1張機(jī)票。”);

else

{

s[i].count=s[i].count+n;

printf(“退票成功!”);

}

printf(“是否繼續(xù)? 請(qǐng)鍵入y或n以回車(chē)鍵結(jié)束: ”);//判定是否繼續(xù)退票

scanf(“%s”,a);}while(!strcmp(a,“y”));//判定并跳出循環(huán)

}

void paixu()//定義排序函數(shù) { int n;

printf(“n******************************************************************************** ”);

printf(“1.按航班號(hào)從小到大排序n”

“t2.按航班號(hào)從大到小排序n”);printf(“******************************************************************************** ”);

printf(“請(qǐng)?jiān)?-2中選擇以回車(chē)鍵結(jié)束: ”);scanf(“%d”,&n);//輸入排序方式

switch(n){

case 1:paixu1();//調(diào)用從小到大排序函數(shù)

break;

case 2:paixu2();//調(diào)用從大到小排序函數(shù)

break;} printf(“排序后的航班信息為:n”);output();

//顯示排序后航班信息

printf(“n請(qǐng)按回車(chē)鍵返回上層菜單 ”);

getchar();

getchar();}

void paixu1()//定義從小到大排序函數(shù) { int k,j;struct air t;for(i=0;i

{

k=i;

for(j=i+1;j

if(s[k].num>s[j].num)

k=j;

if(i!=k)

{

t=s[k];

s[k]=s[i];

s[i]=t;

} } }

void paixu2()//定義從大到小排序函數(shù) {

} int k,j;struct air t;for(i=0;i

if(s[k].num

k=j;if(i!=k){

t=s[k];

s[k]=s[i];

s[i]=t;} }

下載c語(yǔ)言一朵花源代碼word格式文檔
下載c語(yǔ)言一朵花源代碼.doc
將本文檔下載到自己電腦,方便修改和收藏,請(qǐng)勿使用迅雷等下載。
點(diǎn)此處下載文檔

文檔為doc格式


聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶(hù)自發(fā)貢獻(xiàn)自行上傳,本網(wǎng)站不擁有所有權(quán),未作人工編輯處理,也不承擔(dān)相關(guān)法律責(zé)任。如果您發(fā)現(xiàn)有涉嫌版權(quán)的內(nèi)容,歡迎發(fā)送郵件至:645879355@qq.com 進(jìn)行舉報(bào),并提供相關(guān)證據(jù),工作人員會(huì)在5個(gè)工作日內(nèi)聯(lián)系你,一經(jīng)查實(shí),本站將立刻刪除涉嫌侵權(quán)內(nèi)容。

相關(guān)范文推薦

    C語(yǔ)言機(jī)票訂票管理系統(tǒng)源代碼

    #include //標(biāo)準(zhǔn)輸入、輸出頭文件 #include //包含字符串函數(shù)處理頭文件 #include //包含access函數(shù)的頭文件 #include #include #include #include #define N 9999 //定......

    c語(yǔ)言實(shí)現(xiàn)機(jī)票管理系統(tǒng)源代碼

    /*1、用戶(hù)和管理員及航班信息請(qǐng)以英文字母或數(shù)字輸入*/ /*2、管理員賬戶(hù)為:boss,密碼為:123。保存在txt文件中,需要修改請(qǐng)于程序中修改*/ /*3、部分文件讀寫(xiě)為二進(jìn)制讀寫(xiě),所以打......

    源代碼讀后感

    《源代碼》觀后感 看完電影《源代碼》后,我們幾個(gè)人都感嘆不已,圍繞著該如何解釋劇情展開(kāi)了激烈的討論,各有各的說(shuō)法,電影嘛,要的就是這個(gè)效果。從能吸引幾個(gè)不同年齡段不同工種......

    影評(píng)《源代碼》

    這是結(jié)束了還是另一個(gè)延續(xù)?——《源代碼》影評(píng)及觀后感 說(shuō)道穿越,應(yīng)該是最近最火的電影電視劇喜歡使用的內(nèi)容了。其實(shí)穿越的另一個(gè)名字叫做“時(shí)空旅行”。其指的是人從某一時(shí)......

    源代碼影評(píng)

    看完了源代碼,好吧首先來(lái)簡(jiǎn)述一下影片的情節(jié):一位名叫柯?tīng)柼亍な返傥牡纳衔荆橙债?dāng)他醒來(lái)時(shí)發(fā)現(xiàn)自己正在一輛前往芝加哥的火車(chē)上,而他在火車(chē)的主要目的就是要找到是誰(shuí)把炸彈放在......

    c語(yǔ)言課程設(shè)計(jì)-文件加密解密(含源代碼)

    C 語(yǔ) 言 課 程 設(shè) 計(jì) 實(shí) 驗(yàn) 報(bào) 告 實(shí)驗(yàn)名稱(chēng):文件加密解密 院系:軟件學(xué)院 學(xué)號(hào): 年9月3日—9月17日 日期:2012 一:設(shè)計(jì)題目 1:設(shè)計(jì)圖形用戶(hù)界面。 2:對(duì)文件進(jìn)行加密并對(duì)加密文件進(jìn)......

    c語(yǔ)言簡(jiǎn)單的計(jì)算器源代碼(合集5篇)

    1.簡(jiǎn)單的計(jì)算器 #include void main { float calculator(float a,float b,char c); float a,b,d;char c; printf("請(qǐng)輸入加數(shù)和運(yùn)算符號(hào)n"); scanf("%f,%f,%c",&a,&b,&c......

    DES源代碼C語(yǔ)言實(shí)現(xiàn)(簡(jiǎn)潔易懂)(五篇)

    #include /* 初始置換表IP */ int IP_Table[64] = { 57,49,41,33,25,17,9,1, 59,51,43,35,27,19,11,3, 61,53,45,37,29,21,13,5, 63,55,47,39,31,23,15,7, 56,48,40......

主站蜘蛛池模板: 十八禁视频网站在线观看| 天天夜碰日日摸日日澡性色av| 亚州日本乱码一区二区三区| 国产亚洲精品久久久闺蜜| 国产av永久无码天堂影院| 狠狠躁天天躁夜夜躁婷婷| 亚洲 欧美 日韩 综合aⅴ| 国产欧美日韩一区二区搜索| 免费无码专区在线视频| 国产精品白浆无码流出视频| 亚洲精品成a人在线观看| 97se亚洲国产综合自在线| 婷婷五月开心亚洲综合在线| 国产成人理论无码电影网| 色偷偷人人澡人人爽人人模| 99久久国产露脸国语对白| 国产精品熟女在线视频| 蜜臀av性久久久久蜜臀aⅴ| 国产成人亚洲影院在线观看| 无码av一区二区三区不卡| 久久综合精品国产一区二区三区无| 久久久久久中文字幕有精品| 久久久久久伊人高潮影院| 国产成人av男人的天堂| а天堂中文最新一区二区三区| 少妇被黑人到高潮喷出白浆| 亚洲欧洲无码av一区二区三区| 99精品久久久久久久婷婷| 亚洲日本va午夜在线影院| 加勒比无码人妻东京热| 婷婷开心色四房播播| 国产精品 人妻互换| 亚洲精品乱码久久久久久蜜桃不卡| 粗大猛烈进出高潮视频免费看| 国产成人无码av在线播放dvd| 一本无码人妻在中文字幕免费| 鲁丝久久久精品av论理电影网| 夜夜嗨av一区二区三区| 中文字幕无码人妻aaa片| 亚洲欧洲日产国码无码久久99| 日本欧美一区二区三区在线播放|