c++课程设计之菜单选择\\

a) 从键盘输入n个数,选择升序还是降序输出

b)创新了日历

c) 添加了射箭游戏

d)还加入了好玩的24点游戏

 

 

学生签名:        

年  月   日

 

课程设计(论文)评阅意见


等   级


项    目


课程设计态度评价


出勤情况评价


设计中创新性评价


论文书写规范化评价


综合评定等级


优秀




6补充



 


良好




4补充



 


中等




2补充



 


及格




无补充



 


不及格


不好


不好


无补充


不好


 

评阅人  王更生  职称  教 授

2017年  6月  16  日

目 录

一、设计思路

二、功能实现详细设计

三、测试结果分析

四、用户手册

五、设计体会

一、设计思路

首先,(说明一下,一直觉得那些做游戏开发的人非常厉害,于是,我就选了我们课设里面的射箭游戏来做)在做这个程序之前,自己特意去玩了一些射箭游戏qaq,虽然这个射箭游戏玩起来简单,但是要自己来做的话,就很难了。(对于我来说的话)

一开始,我在想那个射箭的箭要怎么来写,肯定是要用字符来做那个箭头的,这就需要很多个for循环来实现了,然后百度上找代码,发现百度上没有qaq(也许是自己比较笨吧,找不到),然后就想起了老师的那个菜单的设计,里面有那个射箭游戏的代码,然后我就拿来了。(说实话,代码看了几天自己才看懂啊,感觉自己真的好笨)。

一开始,觉的这个射箭游戏的内容也太简单了吧,于是,我起初的思路是这样的,(原先的代码运行是只要箭头一碰到那个墙壁的话游戏就结束了)我想那个能不能碰到箭头后可以选择,如果你没选择结束游戏的话,碰到墙壁的话,箭头就转向,再继续走(会转弯的箭诶,哈哈)

我想了一天之后,发现代码还是实现不了(我真的好笨呐),然后,我就换了一种休干的方法,写一个递归函数吧那个游戏弄成一个循环的了(貌似看起来更高级了一点吧),然后你要选择特定的指令这个游戏才会结束,退出程序。于是就写了几个函数

最后还补充了一个24点游戏和一个日历。

1,实现循环和功能选择:编写一个菜单函数menu(),用while循环控制菜单的重复选择,用switch 选择结构对用户的选择,并且实现相应的功能。

2,设计各个选择的功能:对于选择1,利用c++里面的sort函数对一组数字进行排序;对于选择2:添加的24点游戏;对于选择三:设计一个射箭游戏;对于选择4:设计的一个24点游戏;对于选择5:利用while(0)结束程序的运行、。

二、功能实现详细设计

1:switch 选择结构,在主函数里面定义一个变量t,利用while循环,根据t的不同,switch执行指向不同的函数,就是运行菜单中不同的功能。当他等于0 的时候,即while(0),循环不成立,跳出循环,程序就结束了。

2:menu()菜单界面设置函数,主要用于设置菜单的界面

3:排序函数sortq();里面利用了sort()函数对一主数据进行排序,需要使用扥头文件是#include<algorithm>,算法头文件,算法博大精深的,非常有趣。void sortq()

{

int
n,p;

int
a[10005];

cout<<"  请  输  入  要  排  序  的  数  的  个  数  :"<<endl;

cin>>n;

cout<<"  请  输  入  "<<n<<"  个  数  字  "<<endl;

for(int
i=0;i<n;i++)

cin>>a[i];

cout<<"  请  选  择  排  序  方  式  "<<endl<<endl;

sort(a,a+n);

cout<<"  选  1  升  序,选  2  降  序   , 请  选  择
:"<<endl;

cin>>p;

if(p==1)

for(int i=0;i<n;i++)

cout<<a[i]<<"
";

if(p==2)

for(int i=n-1;i>=0;i--)

cout<<a[i]<<"
";

cout<<endl<<endl<<endl;

}//可以选择输出方式,升序和降序。

4设计了chen();cre();exh();这三个函数来实现24点游戏的玩法;

5通过   sjyxhhwo();sfjs();quit();这三个函数来实现射箭游戏的创新;

6通过rili();       这个函数来实现日历的表达;

这些就是代码细节。

三、测试结果分析

四、用户手册

这是一个比较高级的菜单程序设计,使用起来也非常简单的,还是自己介绍一下吧。

首先你编译运行程序,然后出现了提供菜单界面,界面有五个选项,
选择数字1 2 3 4 5;美国数字有不同的功能,比如选择2就是24点游戏,有提示的,耕者提示选择就行了,这个菜单非常有意思的,相信不会让你们失望哦!

五、设计体会

这次的程序设计是我第一次做的程序设计,虽然程序设计的比较简单,qaq,都是自己太笨了,希望老师能原谅一下哦。对于这次设计,花了好久的时间来想的,先是这个起初的箭头的代码及理解了几天,然后又有了自己的思路,一直很想实现这个思路的,然后就一直想他的代码实现,自己尝试了写过很多次,但都没能成功,元婴石左边那个墙我不会做,最后无奈,只能做出这种循环的了。这次的课设,自己觉得还是做得蛮开心的,因为它让我学会了很多,比如那个清屏函数的,那我以后就可以用了,好开心哦。还逼我看会了这么复杂的代码,好多个for 循环啊。。想想就可怕。

  做完这个课程设计,我们的自信一下子提高了,我们也会写程序了;尽管对于有些人这种程序会很简单,可对于我们C语言初学者来说,已经很不容易了。这次体验为以后的学习计算机的我们增强了信心。享受劳动成果的滋味实在美妙啊!

  很感谢这次的课程设计,它使我更加地体会到多看专业书的重要性,只有掌握了一定量的专业知识才能得心应手地解决诸多问题;另外,在做任何事倒要有耐心,不要一遇到困难就退缩;在学习和工作中要时刻谨记团结二字,它好比通向成功的铺路石,不可或缺。

  人生的道路是曲折的,但正是因为曲折人生才光彩夺目,在人生的道路上,总遇到重重困难,但正是因为困难我们才变得更坚强。今后的路还很长,面对困难,让我们用行动去俘虏它吧!

附代码:(比较长)

#include<iostream>

#include<algorithm>

#include<cstdio>

#include <stdlib.h>

using namespace std;

#include<string.h>

#include<math.h>

#include<time.h>

#include <conio.h>

#include <iomanip>

 

 

#define Mon   1

#define Tues  2

#define Wed   3

#define Thur  4

#define Fri   5

#define Sat   6

#define Sun   0

 

#define January_days   31

#define February_days   28

#define March_days    31

#define April_days    30

#define May_days     31

#define June_days     30

#define July_days     31

#define August_days    31

#define September_days  30

#define October_days   31

#define November_days   30

#define December_days   31

 

#define first1month January_days

#define first2month
January_days+February_days

#define first3month
January_days+February_days+March_days

#define first4month January_days+February_days+March_days+April_days

#define first5month
January_days+February_days+March_days+April_days+May_days

#define first6month
January_days+February_days+March_days+April_days+May_days+June_days

#define first7month
January_days+February_days+March_days+April_days+May_days+June_days \

            +July_days

#define first8month
January_days+February_days+March_days+April_days+May_days+June_days \

            +July_days+August_days

#define first9month
January_days+February_days+March_days+April_days+May_days+June_days \

            +July_days+August_days+September_days

#define first10month
January_days+February_days+March_days+April_days+May_days+June_days \

           
+July_days+August_days+September_days+October_days

#define first11month January_days+February_days+March_days+April_days+May_days+June_days
\

           
+July_days+August_days+September_days+October_days+November_days

 

int known_weekday = Tues;

int known_year = 1901;

int konwn_month = 1;

int known_day = 1;

char card[] = { ‘A‘,‘2‘,‘3‘,‘4‘,‘5‘,‘6‘,‘7‘,‘8‘,‘9‘,‘10‘,‘J‘,‘Q‘,‘K‘
}; 

char buf[4]; 

double nums[4]; 

char ope[4] = { ‘+‘,‘-‘,‘*‘,‘/‘ }; 

 

 

/********************************************************************************/

void menu()

{

   cout<<"\n\t\t\t\t\t**********菜单选择**********"<<endl;

   cout<<"\n\t\t\t\t\t1.********数字排序**********"<<endl;

   cout<<"\n\t\t\t\t\t2.********24点游戏**********"<<endl;

   cout<<"\n\t\t\t\t\t3.*******射箭游戏***********"<<endl;

   
cout<<"\n\t\t\t\t\t4.*********
万年历***********"<<endl;

   cout<<"\n\t\t\t\t\t5.********退出程序**********"<<endl;

   
cout<<"\n\t\t\t\t\t****************************"<<endl;

}

/********************************************************************************/

 

void sortq()

{

   int
n,p;

   int
a[10005];

   cout<<"  请  输  入  要  排  序  的  数  的  个  数  :"<<endl;

   cin>>n;

   cout<<"  请  输  入  "<<n<<"  个  数  字  "<<endl;

   for(int
i=0;i<n;i++)

      cin>>a[i];

      
cout<<" 
请  选  择  排  序  方  式  "<<endl<<endl;

      sort(a,a+n);

      cout<<"  选  1  升  序,选  2  降  序   , 请  选  择 :"<<endl;

      cin>>p;

      if(p==1)

      for(int i=0;i<n;i++)

         cout<<a[i]<<"
";

   

       if(p==2)

         for(int i=n-1;i>=0;i--)

         cout<<a[i]<<"
";

     

         cout<<endl<<endl<<endl;

  

}

/********************************************************************************************************/

int day_count(int month)

   switch(month)

   {

      case
1: return 0;break;

      case
2: return first1month;break;

      case
3: return first2month;break;

      case
4: return first3month;break;

      case
5: return first4month;break;

      case
6: return first5month;break;

      case
7: return first6month;break;

      case
8: return first7month;break;

      case
9: return first8month;break;

      case
10: return first9month;break;

      case
11: return first10month;break;

      case
12: return first11month;break;

   }

}

 

char * month_name(int month)

{

   switch(month)

   {

      case
1:

         return
"
一月";

         break;

      case
2:

         return
"
二月";

         break;

      case
3:

         return
"
三月";

         break;

      case
4:

         return
"
四月";

         break;

      case
5:

         return
"
五月";

         break;

      case
6:

         return
"
六月";

         break;

      case
7:

         return
"
七月";

         break;

      case
8:

         return
"
八月";

         break;

      case
9:

         return
"
九月";

         break;

      case
10:

         return
"
十月";

         break;

      case
11:

         return
"
十一月";

         break;

      case
12:

         return
"
十二月";

         break;

      default:

         break;

   }

}

void first_line_print(int month, int
year)

{

   printf("%8d年 %s \n",year, month_name(month));

}

 

void week_print()

{

   printf("%-3s%-3s%-3s%-3s%-3s%-3s%-3s\n","日", "一", "二", "三", "四", "五", "六");

}

 

int date_distance_count(int month, int
year)

{

   int
leap_year_count = 0;

   int
i;

   int
distance;

 

   if
(year > known_year)

   {

      for
(i=known_year; i<year; i++)

      {

         if(((i%4
== 0) && (i%100 != 0) ) || (i%400 == 0))

         {

            leap_year_count++;   

         }

      }

 

      if
(month > 2)

      {

         if(((year%4
== 0) && (year%100 != 0) ) || (year%400 == 0))

         {

            leap_year_count++;   

         }

      }

   }

   else

   if
(year == known_year)

   {

      if
(month > 2)

      {

         leap_year_count
= 1;

      }

   }

  

 

   distance
= (year - known_year)*365 + leap_year_count + day_count(month);

 

   return
distance;  

}

 

int makesure_firstday_weekday(int
month, int year)

{

   int
date_distance = 0;

   int
weekday;

 

   date_distance
= date_distance_count(month, year);

   weekday
= (known_weekday + date_distance)%7;

 

   return
weekday;

}

 

void print_in_turn(int month, int
firstday, int year)

{

   int
i = 1;

   int
weekday;

 

   switch(firstday)

   {

      case
Sun:

         break;

      case
Mon:

         printf("%-3s","");

         break;

      case
Tues:

         printf("%-6s","");

         break;

      case
Wed:

         printf("%-9s","");

         break;

        

      case
Thur:

         printf("%-12s","");

         break;

      case
Fri:

         printf("%-15s","");

         break;

      case
Sat:

         printf("%-18s","");

         break;

   }

 

   switch(month)

   {

      case
1:

      case
3:

      case
5:

      case
7:

      case
8:

      case
10:

      case
12:

      {

         for(i=0;
i<31; i++)

         {

            weekday
= (firstday + i)%7;

            printf("%-3d",i+1);

           

            if(weekday
== Sat)

            {

                printf("\n");

            }              

         }

         break;

      }

      case
2:

      {

         if(((year%4
== 0) && (year%100 != 0) ) || (year%400 == 0)) /*
闰年*/

         {

            for(i=0;
i<29; i++)

            {

                weekday
= (firstday + i)%7;

                printf("%-3d",i+1);

               

                if(weekday
== Sat)

                {

                   printf("\n");

                }              

            }

            break;

         }

         else

         {

            for(i=0;
i<28; i++)

            {

                weekday
= (firstday + i)%7;

                printf("%-3d",i+1);

               

                if(weekday
== Sat)

                {

                   printf("\n");

                }              

            }

            break;

         }

     

      }

      case
4:

      case
6:

      case
9:

      case
11:

      {

         for(i=0;
i<30; i++)

         {

            weekday
= (firstday + i)%7;

            printf("%-3d",i+1);

           

            if(weekday
== Sat)

            {

                printf("\n");

            }              

         }

         break;

      }       

   }

}

 

void date_print(int month, int year)

{

   int
firstday;

 

   firstday
= makesure_firstday_weekday(month, year);

   print_in_turn(month,
firstday, year);

   printf("\n");

}

 

void main_month(int month, int year)

{

   first_line_print(month,
year);

   week_print();

   date_print(month,
year);

   printf("\n\n");

}

 

void main_calendar(int year)

{

   int
i;

   for(i=1;
i<=12; i++)

   {

      main_month(i,
year);

   }

}

 

void rili()

{

   int
year;

 

   printf("请输入年份:year = ");

   scanf("%d",&year);

   printf("\n");

 

   while(year
< 1902)

   {

      printf("请输入大于1901的年份\n");

 

      printf("请输入年份:year = ");

      scanf("%d",&year);

      printf("\n");

   }

  

   main_calendar(year);

  

   scanf("
");

   //return
0;

}//日历

 

/******************************************************************************************************************/

 

 

void chen()

{

    cout<< "             
################################################" <<
endl 

       
<< "             
#                                              #" << endl 

       
<< "             
#             
欢迎进入24点游戏                #" << endl 

       
<< "             
#                                             
#" << endl 

       
<< "             
################################################" <<
endl<<endl<<endl; 

}

 

void cre()//输入四张牌面 


   
//char buf[4];

   
printf("
输入的四张牌面为:"); 

    

   
for (int i = 0; i<4; i++) 

   

      
cin>>buf[i];

       
//scanf("%c",&buf[i]);

      if
(buf[i] == ‘A‘) nums[i] = 1; 

       
else if(buf[i] == ‘2‘) nums[i] = 2; 

       
else if (buf[i] == ‘3‘) nums[i] = 3; 

       
else if (buf[i] == ‘4‘) nums[i] = 4; 

       
else if (buf[i] == ‘5‘) nums[i] = 5; 

       
else if (buf[i] == ‘6‘) nums[i] = 6; 

       
else if (buf[i] == ‘7‘) nums[i] = 7; 

       
else if (buf[i] == ‘8‘) nums[i] = 8; 

       
else if (buf[i] == ‘9‘) nums[i] = 9; 

       
else if (buf[i] == ‘10‘) nums[i] = 10; 

       
else if (buf[i] == ‘J‘) nums[i] = 11; 

       
else if (buf[i] == ‘Q‘) nums[i] = 12;  

       
else if (buf[i] == ‘K‘) nums[i] = 13; 

       

   


 

double calcute(double a, double b, char
index) 


   
if (index == ‘+‘) return a + b; 
//
若为+,则返回相应结果    

   
else if (index == ‘-‘) return a - b; 

   
else if (index == ‘*‘) return a*b; 

   
else if (index == ‘/‘) 

       
if (b != 0) 

            return a / b;    //只有当分母不为0时,返回结果  


 

void exh()//穷举计算 


   
double  temp[3], tem[2];   //
第一个符号放置后,经过计算后相当于剩下三个数,这个数组用于存储这三个数   

   
double  sum;  //
求得的和   

   
int  judge = 0;   //
判断是否找到一个合理的解    

   
for (int i = 0; i < 4; i++)  //
第一次放置的符号   

   

       
for (int j = 0; j < 4; j++)  
//
第二次放置的符号    

       

            for (int k = 0; k < 4; k++)    //第三次放置的符号     

            { 

                for (int m = 0; m < 3;
m++)      //
首先计算的两个相邻数字,共有3种情况,相当于括号的作用      

                { 

                    if (nums[m + 1] == 0
&& ope[i] == ‘/‘) break; 

                    temp[m] = calcute(nums[m],
nums[m + 1], ope[i]); 

                    temp[(m + 1) % 3] = nums[(m
+ 2) % 4]; 

                    temp[(m + 2) % 3] = nums[(m + 3) %
4];      //
先确定首先计算的两个数字,计算完成相当于剩下三个数,按顺序储存在temp数组中        

                    for (int n = 0; n < 2;
n++)       //
三个数字选出先计算的两个相邻数字,两种情况,相当于第二个括号        

                    { 

                        if (temp[n + 1] == 0
&& ope[j] == ‘/‘) break; 

                        tem[n] =
calcute(temp[n], temp[n + 1], ope[j]); 

                        tem[(n + 1) % 2] =
temp[(n + 2) % 3];        //
先确定首先计算的两个数字,计算完成相当于剩下两个数,按顺序储存在temp数组中         

                        if (tem[1] == 0 && ope[k] == ‘/‘)
break; 

                        sum = calcute(tem[0],
tem[1], ope[k]);       //
计算和                

                        if (sum == 24)        //若和为24        

                        { 

                            judge = 1;         //判断符为1,表示已求得解           

                            if (m == 0
&& n == 0) 

                                cout <<
"((" << nums[0] << ope[i] << nums[1] <<
")" << ope[j] << nums[2] << ")" <<
ope[k] << nums[3] << "=" << sum << endl; 

                            else if (m == 0
&& n == 1) 

                                cout <<
"(" << nums[0] << ope[i] << nums[1] <<
")" << ope[k] << "(" << nums[2] <<
ope[j] << nums[3] << ")=" << sum <<
endl; 

                            else if (m == 1
&& n == 0) 

                                cout <<
"(" << nums[0] << ope[j] << "(" <<
nums[1] << ope[i] << nums[2] << ")" << ope[k]
<< nums[3] << "=" << sum << endl; 

                            else if (m == 1
&& n == 1) 

                                cout << nums[0] << ope[k]
<< "((" << nums[1] << ope[i] << nums[2]
<< ")" << ope[j] << nums[3] << ")="
<< sum << endl; 

                            else if (m == 2
&& n == 0) 

                                cout <<
"(" << nums[0] << ope[j] << nums[1] <<
")" << ope[k] << "(" << nums[2] <<
ope[i] << nums[3] << ")=" << sum <<
endl; 

                            else if (m == 2
&& n == 0) 

                                cout <<
nums[0] << ope[k] << "(" << nums[1] << ope[j]
<< "(" << nums[2] << ope[i] << nums[3]
<< "))=" << sum << endl;          //m=0,1,2 n=0,1
表示六种括号放置可能,并按照这六种可能输出相应的格式的计算式                

                        } 

                    } 

                } 

            } 

       

   

   
if (judge == 0) 

       
cout << "
这四张扑克牌无法找到一个合理的解"
<< endl;  //如果没有找到结果,符号位为0  


   
//24
点游戏

/****************************************************************************************************************************/

 

 

void quit()

{

   cout<<"\n\n\n\t\t\t谢 谢 欣 赏 此 射 箭 游 戏 !\n\n";

// exit(0);

}

 

void sjyxhhwo()

{

  

   int
i,j,k=0;

   char
ch=‘ ‘;

   do

   {

      if(ch==‘q‘)

      {

         system("cls");

         cout<<"\n\t键入了Q键,游戏中途退出了哦,结束游戏就按q哦,继续玩按其他键喔 "<<endl;

         break;

      }

      switch(ch)

      {

      case
‘1‘:

      case
‘2‘:

      case
‘3‘:

      case
‘4‘:

      case
‘5‘:

      case
‘6‘:

      case
‘7‘:

      case
‘8‘:

      case
‘9‘: k+=int(ch-‘0‘);//
把字符转化为对应的数字

      }

      system("cls");

      cout<<"请输入1-9(数字表示箭跳格的个数),键入Q键或者箭头触壁退出,键入其它键箭不动"<<endl;

      cout<<"\n\n\n";

 

      for(i=0;i<7;i++)

      {

         for(j=0;j<k;j++)

            cout<<"
";

         if((i==0)||(i==6))

         {

             cout<<"$";

          

            for(j=0;j<69-k;j++)

            {

                if(j==0) cout<<"@";

                cout<<"
";}

            cout<<"@";

     

         }

         else
if(i<3)

         {

            for(j=0;j<i;j++)

                cout<<"
";

            cout<<"$";

            for(j=0;j<-i+32;j++)//33-2=a*1+b;33-3=a*2+b

                cout<<"
";

            for(j=0;j<2*i-1;j++)//1=a*1+b;3=a*2+b

                cout<<"*";

            for(j=0;j<-2*i+39-k;j++)//71-34-k=a*1+b;71-36-k=a*2+b

                cout<<"
";

            cout<<"@";

         }

         else
if(i==3)

         {

            for(j=0;j<i;j++)

                cout<<"
";

            for(j=0;j<30;j++)

                cout<<"#";

            for(j=0;j<2*i-1;j++)

                cout<<"*";

               

            if(k>=34)//72-38

            {

                //cout<<endl;

                system("cls");

               

                goto
quit;

                   //sfjs();

            }

            for(j=0;j<-2*i+39-k;j++)

                cout<<"
";

            cout<<"@";

         }

         else

         {

            for(j=0;j<-i+6;j++)//2=a*4+b;1=a*5+b

                cout<<"
";

            cout<<"$";

            for(j=0;j<i+26;j++)//33-3=a*4+b;33-2=a*5+b

                cout<<"
";

            for(j=0;j<-2*i+11;j++)//3=a*4+b;1=a*5+b

              cout<<"*";

            for(j=0;j<2*i+27-k;j++)//71-36-k=a*4+b;71-34-k=a*5+b

                cout<<"
";

            cout<<"@";

         }

         cout<<endl;

      }

   }while(ch=getch());

   quit:

// cout<<"
\n\n\n\n\t
按任意键,返回菜单!"<<endl;

   getch();

    

   
}

   

void sfjs()

{  

   
cout<<"
你 是 否 还 要 玩 游 戏 呢 ?不 玩 就 按 q 哦 qaq"<<endl;

   char
ch1;

// cout<<"你 是 否 还 要 玩 游 戏 呢 ?不 玩 就 按 q 哦
qaq"<<endl;

   cin>>ch1;

   system("cls");

   //cout<<"你 是 否 还 要 玩 游 戏 呢 ?不 玩 就 按 q 哦
qaq";

   if(ch1==‘q‘){

  

   cout<<"\n\n\t\t\tQWQ    游戏结束了哦    QWQ"<<endl;

// goto
quit;

// quit:;

    }

   else

   {

  

   sjyxhhwo();

   sfjs();

}

}

 

  
//
射箭游戏

/***********************************************************************************************************************************/

 

int main()

{

   int
a,t=1;

   while(t)

   {

      menu();

         cout<<"     请选择1—5:"<<endl;

      cin>>a;

      cout<<endl;

         system("cls");

      switch(a)

      {

           

      case
1:

            sortq();

            break;

      case
2:

            chen();cre();exh();

            break;

      case
3:

                sjyxhhwo();sfjs();quit();

                break;

      case
5:

                   t=0;

                   break;

      case
4:

                rili(); 

                break;

}

}

   
cout<<"
程序结束,退出菜单"<<endl;

}

时间: 2024-11-14 09:52:50

c++课程设计之菜单选择\\的相关文章

课程设计(物体类),图片可能没有加载出来,自己运行一下就行了

一.课程设计题目与要求(包括题目与系统功能要求) A.<1>设计如下类,其功能和部分成员如下: Object:抽象类,所有的物体都有价值(profit)属性: Point:点的位置: Line(线段),Rectangle,Cuboid, Square,Cube,Circle,Cylinder. <2>功能:能够实现上述物体的移动(move),放大(zoomin),缩小(zoomout),大小比较(compare),打印物品信息(cout<<编号.面积.容积和价值)等操作

C语言课程设计—图书管理系统

这是本人大一第二学期初C语言课程设计的作品,嘿嘿,本来以为已经找不到原稿了,今天无意中居然在QQ网络硬盘中找到了当初的teta版,公布于此,以作纪念. C源码例如以下: #include<stdio.h> #include<stdlib.h> #include<string.h> struct book{ char book_name[30]; int bianhao; double price; char author[20]; char state[20]; cha

数据结构课程设计之一元多项式的计算

数据结构不是听会的,也不是看会的,是练会的,对于写这么长的代码还是心有余也力不足啊,对于指针的一些操作,也还是不熟练,总出现一些异常错误,对于数据结构掌握还是不够啊,还是要多练,这个课程设计做的还是有点粗糙,还有待改进啊!! 对代码有进行了一下改进,增加了排序的模块:可能还存在着一下小bug,发现了再更新:减法还可以写的更简便一点. <pre name="code" class="cpp">#include <stdio.h> #includ

帮初中同学做的简单的课程设计

因为同学没学链表,结构体,只能简单并且麻烦的做了一个课程设计.内容为存储学生信息和考试成绩,对成绩单进行编辑,排序,删除,显示等功能. 代码如下: 1 #include <stdio.h> 2 #include <conio.h> 3 #include <string.h> 4 #define NUMSTU 5000 /*最大学生人数*/ 5 #define NUMSCORE 4 /*成绩个数*/ 6 #define NAMELEN 100 /*姓名的最大长度<1

学生管理系统-火车订票系统 c语言课程设计

概要: C 语言课程设计一---学生管理系统 使使用 C 语言实现学生管理系统.系统实现对学生的基本信息和考试成绩的 管理.采用终端命令界面,作为系统的输入输出界面.采用文件作为信息存储介质. 功能描述: 学生信息: 基本信息: 学号: int 姓名: char 128 密码: char 32 年龄: int 班级: int 成绩信息: 数学成绩: int C 语言成绩:int 语文成绩: int 名次: int 1.  实现对学生信息基本信息的录入,其中名次根据成绩自动计算(添加).学号不能

大二第一学期期末课程设计 2015.12.28

<数据结构与算法>课程设计教学任务书 --2015-2016(一)   课程设计周数:2周                                                              一.课程设计的目的 数据结构课程主要是研究非数值计算的程序设计问题中所出现的计算机操作对象以及它们之间的关系和操作的学科.数据结构是介于数学.计算机软件和计算机硬件之间的一门计算机专业的核心课程,它是计算机程序设计.数据库.操作系统.编译原理及人工智能等的重要基础,广泛的应用于信息学

数据结构课程设计《稀疏矩阵运算器》

最近正在弄数据结构课程设计内容,说实话,感觉自己数据结构学的就是渣,好多东西都不会.还是要多学点东西啊.现在暂且贴点之前写完的东西吧,到时候也好有个总结. 1 诸论 1.1 问题描述 稀疏矩阵是指那些多数元素为零的矩阵.利用"稀疏"特点进行存储和计算可以大大节省存储空间,提高计算准备效率.实现一个能进行稀疏矩阵基本运算的运算器. 1.2 基本要求 以"带行逻辑链接信息"的三元组顺序表示稀疏矩阵,实现两个稀疏矩阵相加.相减.相乘和求逆的运算.稀疏矩阵的输入形式采用三元

背单词系统 数据结构课程设计

     数据结构     课程设计说明书           题目:          轻松背单词   学生姓名:       啦啦啦 学    号:    201406060306      院 (系):    电气与信息工程 专    业:   计算机科学与技术 指导教师: 2016  年  1 月 15 日 目 录 1.设计任务 1 2. 需求分析 1 3. 概要设计 1 3.1 基本功能 1 3.2 函数说明 1 3.3 变量和结构体说明 2 3.4 单词存储简要分析 2 3.5 功能

数据结构课程设计论文--学生信息管理系统

数据结构课程设计论文--学生信息管理系统 1.学生成绩分析问题 (1)问题描述.录入并保存一个班级学生多门课程的成绩,并对成绩进行分析. (2)基本要求.a)通过键盘输入各学生的多门课程的成绩,建立相应的文件input.dat.b)对文件input.dat中的数据进行处理,要求具有如下功能:按各门课程成绩排序,并生成相应的文件输出:计算每个人的平均成绩,按平均成绩排序,并生成文件:求出各门课程的平均成绩.最高分.最低分.不及格人数.60~69分人数.70~79分人数.80~89分人数.90分以上