当前位置:首页 » 编程语言 » c语言课程设计思路
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

c语言课程设计思路

发布时间: 2022-07-01 16:20:43

A. c语言课程设计

main()
{
int i,j;
scanf("%d",&i);
j=i/10
switch(i)
{
case 10:
case 9: printf("优秀"); break;
case 8: printf("良好"); break;
case 7: printf("中等"); break;
case 6: printf("及格"); break;
case 5:
case 4:
case 3:
case 2:
case 1:
case 0: printf("不及格"); break;
default : printf("输入有误");
}
}

B. c语言课程设计:图书管理系统设计的基本思路是什么

图书管理系统主要要求可以录入书籍,添加书目,查找书本信息,删除或修改信息,有的还要求显示是否被借阅等。

一般采用结构体数组,链表,文件操作和自定义函数。主要是需要对基础知识掌握牢固。

先定义结构体,然后对结构体的成员进行定义,选择数组存储书本各种信息。录入信息可以用for和do while循环等来做。

存放信息需要文件操作函数,比如fopen,fwrite等。

删除和添加可以删除节点或者增加节点。

查找之类的可以用字符串操作的各种函数实现。

附上参考源代码

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<conio.h>
#definebooks"f:\books.txt"
#definebooksbak"f:\booksbak.txt"
structbookinfo
{
charisbn[20];
chartitle[30];
charauthor[20];
intcount;
};

structbook
{
structbookinfoonebook;
structbook*next;
};

structbook*searchBook(structbook*listptr,charisbn[])
{
while(listptr!=(structbook*)0)
if(strcmp(listptr->onebook.isbn,isbn)==0)
returnlistptr;
else
listptr=listptr->next;
return(structbook*)0;
}


voidMainSearchbook(structbook*firstptr)
{
structbook*ptr;
charisbnno[20];
printf("请输入ISBN:");
scanf("%s",&isbnno);
ptr=searchBook(firstptr,isbnno);
if(ptr!=(structbook*)0)
{
printf("找到了!!! ");
printf("ISBN:%s ",ptr->onebook.isbn);
printf("Title:%s ",ptr->onebook.title);
printf("Author:%s ",ptr->onebook.author);
}
else
printf("sorry,notfound!!! ");
}intaddBook(structbook*listptr,structbookinfonote)
{
while(listptr->next!=0)
listptr=listptr->next;
listptr->next=(structbook*)malloc(sizeof(structbook));
listptr->next->onebook=note;
listptr->next->next=0;
return0;

}

voidMainAdd(structbook*listptr,FILE*fp)
{
intok;
structbookinfonote;
printf("请输入ISBN:");
scanf("%s",¬e.isbn);
printf("请输入Title:");
scanf("%s",¬e.title);
printf("请输入Author:");
scanf("%s",¬e.author);
ok=addBook(listptr,note);
if(ok==0)
{
//将加入的图书写到文件中保存
fprintf(fp," %s%s%s%d",note.isbn,note.title,note.author,0);
printf("添加图书成功!!! ");
}
else
printf("添加图书失败!!! ");
}


intremoveBook(structbook*listptr,charisbn[])
{
while(listptr->next!=(structbook*)0)
{
if(strcmp(listptr->next->onebook.isbn,isbn)==0)
{
listptr->next=listptr->next->next;
return0;
}
else
listptr=listptr->next;
}

return-1;
}

voidMainRemove(structbook*listptr,FILE*fp)
/************************************************************************/
/*删除书籍函数,通过ISBN删除链表节点,同时删除文件中对应信息*/
/*删除文件中一行,用的是笨方法,把需要的信息写到新文件,删除旧文件,重命名..*/
/************************************************************************/
{
charisbnno[20];
intok;
structbookinfoonebook;
printf("请输入ISBN:");
scanf("%s",&isbnno);
ok=removeBook(listptr,isbnno);
if(!ok)
{
FILE*fpbak;
if((fpbak=fopen(booksbak,"a+"))==NULL)
printf("文件打开失败!!! ");
fseek(fp,0,SEEK_SET);//移到文件开始
while((fscanf(fp,"%s%s%s%d ",&onebook.isbn,&onebook.title,&onebook.author,&onebook.count))!=EOF)
{
if(strcmp(onebook.isbn,isbnno)!=0)
{
fprintf(fpbak,"%s%s%s%d ",onebook.isbn,onebook.title,onebook.author,onebook.count);
}
}
fclose(fp);
fclose(fpbak);
if(remove(books))//删除失败返回非0
{
printf("删除文件失败!!! ");
return;
}
else
if(rename(booksbak,books))//重命名失败返回非0值
{
printf("重命名失败!!! ");
return;
}

printf("删除成功!!! ");
}
else
printf("查无此书!!!");
}

intchoice(void)
{
intc;
printf("1.查看图书 ");
printf("2.添加图书 ");
printf("3.删除图书 ");
printf("4.退出程序 ");
printf("请选择序号:");
returnc=getchar();
//returnc=getche();
printf(" ");

}

intaddEntry(FILE*fp,structbook*firstptr)
/************************************************************************/
/*主要用来加载文件中存放的图书信息*/
/************************************************************************/

{
structbookinfoonebook;
while((fscanf(fp,"%s%s%s%d ",&onebook.isbn,&onebook.title,&onebook.author,&onebook.count))!=EOF)
{
while(firstptr->next!=0)
firstptr=firstptr->next;
firstptr->next=(structbook*)malloc(sizeof(structbook));
firstptr->next->onebook=onebook;
firstptr->next->next=0;
}
return0;

}


intmain(intargc,char*argv[])
{
intch;
structbookfirst;
strcpy(first.onebook.isbn,"123456");
strcpy(first.onebook.title,"ProgrammingC");
strcpy(first.onebook.author,"yhb");
first.next=0;
structbook*firstptr=&first;//链表头指针
FILE*fp;
if((fp=fopen(books,"a+"))==NULL)
printf("文件打开失败!!!");
addEntry(fp,firstptr);
while(1)
{
system("CLS");//清屏
/************************************************************************/
/*想想这里为什么要清空缓冲区?*/
/*由于上一次(choice函数)的getchar(),还有一个' '留在缓冲区....*/
/*可以把这句话注释掉看看,没有这句话会遇到麻烦*/
/*如果不用fflush,可以将上面的getchar()换成getche()*/
/*比较getchar(),getch(),getche()......*/
/************************************************************************/
fflush(stdin);
ch=choice()-48;
switch(ch)
{
case1:
MainSearchbook(firstptr);
break;
case2:
MainAdd(firstptr,fp);
break;
case3:
MainRemove(firstptr,fp);
break;
case4:
printf("谢谢使用... ");
exit(0);
default:
printf("请输入正确序号!");
}
system("PAUSE");
}
return0;
}

C. C语言课程设计 简单的.....

Answer To Question 1 & 2 :

充分利用ISO组织于1999年通过的C语言国际标准中的库函数即可实现第一题。利用简单的双重循环即可解决问题二,用递归算法不是好的选择。

第一题完整源码:
(注意:本源码中,函数GetWeekDay的返回值仅仅表示输入参数是否“正确/有效”(例如前三个参数使用2001,2,29就是无效参数),能否得到预期的星期值;真正的星期值则是通过输出变量返回给主调函数的。)
////////////////////////////////////////////
#include <time.h>
#include <stdio.h>

int GetWeekDay(int nYear,int nMon,int nDay, int *npWeekDay);

int main()
{
int nMyWeekDay;
int nResult;

nResult = GetWeekDay(2007,1,10,&nMyWeekDay);

return 0;
}

//输入日期,返回星期的C语言函数
int GetWeekDay(int nYear,int nMon,int nDay, int *npWeekDay)
{
int nRetVal = 0;
time_t tMyDateTime;
struct tm tmMyDate,*tmpMyDate;

if((nYear<1900||nYear>=3000)
|| (nMon<1 || nMon>12)
|| (nDay<1||nDay>31) )
{
nRetVal = 1;
*npWeekDay = -1;
return nRetVal;
}
//memset(tmMyDate,0,sizeof(struct tm));
tmMyDate.tm_year = nYear-1900;
tmMyDate.tm_mon = nMon-1;
tmMyDate.tm_mday = nDay;
tmMyDate.tm_hour =16;
tmMyDate.tm_min =30;
tmMyDate.tm_sec =30;

tMyDateTime = mktime(&tmMyDate);
if(tMyDateTime<0)
{
nRetVal = 1;
*npWeekDay = -1;
return nRetVal;
}
tmpMyDate = localtime(&tMyDateTime);
*npWeekDay = tmpMyDate->tm_wday;
return nRetVal;
}
//Over

////////////////////////////////////////////////////
第二题:
#include <time.h>
#include <stdio.h>

int Sum(int n, int a);

int main()
{

//出题者可以自己将此处改为要求操作人键入N/A的值
int n=5,a=2,s;

s = Sum(n,a);

return 0;
}

//解决问题的函数
int Sum(int n, int a)
{
int nSum =0;
int nTmp;
int i,j;

for(i=1;i<=n; i++)
{
nTmp =a;
for(j=1;j<=i;j++)
{
nTmp += a*10*(j-1);
}
nSum += nTmp;
}
return nSum;
}

D. 想了半天,实在是没有思路,谁能给我点提示啊!不胜感激c语言课程设计

提示一句:一个数的层数为,它所有因数中层数最大的那个因数的下一层。

然后就有了以下构造过程:

voidinitList(){
inti;
structMyNode*tail=&head;
for(i=1;i<=N;i++){
structMyNode*p=(structMyNode*)malloc(sizeof(structMyNode));
p->num=i;
intmaxLay=0;
structMyNode*q;
for(q=head.pNext;q;q=q->pNext){
if(p->num>q->num&&p->num%q->num==0){
if(q->lay+1>maxLay){
maxLay=q->lay+1;
}
}
}
p->lay=maxLay;
tail->pNext=p;
p->pNext=NULL;
tail=p;
}
}

然后简单的排序和输出就行了

E. c语言课程设计报告

#include<stdio.h>
#include<conio.h>
int
CF(int
i)/*求10的i次方的函数*/
{
int
j,m=1;
for(j=0;j<i;j++)
m=10*m;
return
m;
}
void
sort(int
fun[],int
n)/*对分离后的六个数进行从小到大排序*/
{
int
i,j,temp;
for(i=0;i<n-1;i++)
{
for(j=i+1;j<n;j++)
{
if(fun[i]>fun[j])
{
temp=fun[i];
fun[i]=fun[j];
fun[j]=temp;
}
}
}
}
int
pick(int
a,int
s)/*挑选这个数乘以s后满足的数a*/
{
int
i;
int
fun1[6],fun2[6],b;
b=a*s;
for(i=0;i<6;i++)
{
fun1[i]=a%CF(i+1)/CF(i);/*求这个六位数每位上的数字*/
fun2[i]=b%CF(i+1)/CF(i);
}
sort(fun1,6);/*对数字进行排序*/
sort(fun2,6);
for(i=0;i<6;i++)
{
if(fun1[i]!=fun2[i])
break;/*依次进行比较,如果均相同即满足,返回1*/
}
if(i==6)
return
1;
else
return
0;
}
int
search(int
a[],int
s)/*搜索到满足题意的结果保存在数组a[]中*/
{
int
i,n=0;
for(i=100000;i<166668;i++)
{
if(pick(i,s))
{
a[n]=i;
n++;
}
else
continue;
}
return
n;
}
void
print(int
a[],int
n)/*在屏幕上打印结果*/
{
int
i;
for(i=0;i<n;i++)
{
printf("%d
",a[i]);
}
printf("\n\n");
}
void
main()
{
int
a[100],m,s[5]={2,3,4,5,6},i;
for(i=0;i<5;i++)
{
printf("这个数乘以%d后满足条件的结果\n",s[i]);
m=search(a,*(s+i));
print(a,m);
}
getch();
}
这个程序是求出一个六位数乘以2,3,4,5,6后得到的六位数仍由原书的数字组成,并分别输出结果。

F. c语言课程设计目的

没得题目??那就随便写三。。。比如啥子增加编程技巧,熟练对你那个编程软件的应用,巩固你们教的所学的啥子知识什么的````

G. C语言课程设计求解释。。。

#include <stdio.h>
struct student //定义一个结构体
{
char no[20];

char name[20];

float math,english,computer;

double total;

double avr;
};
struct student stu[50]; //定义stu结构体数组
//以下四个是函数声明语句
struct student input(); //学生数据输入函数,返回值是结构体
void display(struct student stu[],int count); //显示函数
void sort(struct student stu[],int count); //排序函数
void stat(struct student stu[],int count); //成绩分析函数

void main()
{
int count;

char ch;

ch='y';

printf("请按以下格式输入学生信息(可用Tab键对齐):");

printf("\n");

count=0;

while ((ch=='y') || (ch=='Y'))
{
stu[count]=input(); //调用input函数输入一个学生的信息给stu数组

count++; //这个循环是当ch为y时添加学生成绩信息

printf("\n是否继续?(按Y继续,其它结束)");

scanf(" %c",&ch);
}
printf("\n学生信息如下:");

sort(stu,count); //调用排序函数进行排序

display(stu,count); //显示排序后的结构

stat(stu,count); //调用分析函数显示分析结果
system("PAUSE"); //我这里加了一个暂停语句,可以把结果停留在输出窗口观看
}

struct student input()
{ int i;
struct student studn;

while(1) //这个循环是当有学号重复时让用户重复输入
{printf("\n学号\t\t姓名\t数学\t英语\t计算机\n");
while(1)
{scanf("%s %s %f %f %f",&studn.no,studn.name,&studn.math,&studn.english,&studn.computer);
if((studn.math>0)&&(studn.math<=100)&&(studn.english>0)&&(studn.english<=100)&&(studn.computer>0)&&(studn.computer<=100))break;
printf("输入的成绩不符合要求,请重新输入\n");
fflush(stdin);}
for(i=0;i<50;i++) //这个循环是查找stu数组中有没有和输入的学号有重复的信息,
if(strcmp(stu[i].no,studn.no)==0)break; //如果有就用break跳出for循环
if(i==50)break; //如果for循环后i值等于50,表示该学号没有重复,用break跳出while循环
printf("输入的学号已存在,请重新输入\n");
}
studn.total=studn.math+studn.english+studn.computer; //计算该学生的总分

studn.avr=studn.total/3.0; //计算该学生的平均分

return studn;
}

void display(struct student stu[],int count)
{ //这个函数很简单,用循环把stu数组的内容输出来
int i;

printf("\n排名\t学号\t\t姓名\t数学\t英语\t计算机\t总分\t平均分");

printf("\n");

for(i=0;i<count;i++)
{
printf("%d",i+1);

printf("\t%s",stu[i].no);

printf("\t%s",stu[i].name);

printf("\t%.1f",stu[i].math);

printf("\t%.1f",stu[i].english);

printf("\t%.1f",stu[i].computer);

printf("\t%.2f",stu[i].total);

printf("\t%.2f",stu[i].avr);

printf("\n");
}
}

void sort(struct student stu[],int count)
{ //这个函数是把stu数组进行排序
int i,j;

struct student t;

for(i=0;i<count;i++) //排序方法是冒泡排序

for(j=0;j<count-i-1;j++)
{
if(stu[j].avr<stu[j+1].avr) //按每个学生的3科平均分大小有高到低排序
{
t=stu[j];

stu[j]=stu[j+1];

stu[j+1]=t;

}
}
}
void stat(struct student stu[],int count)
{ //这个是分数段处理函数
int i;

double avr=0;

for(i=0;i<count;i++) //这个循环是统计全班3科成绩平均分的班的总平均分

avr += stu[i].avr;

avr /= count;

printf("全班平均分为%.2f,\n在平均分以上的同学有:\n",avr);

for(i=0;i<count;i++) //这个循环的功能上面printf语句说得很清楚了

if(stu[i].avr>=avr)
{
printf("%s\t",stu[i].name);
}
printf("\n");
}

H. c语言课程设计!急!!!

#include<stdio.h>
#include<stdlib.h>//应用动态存储分配函数//
#include<time.h>
# define LEN sizeof(struct question)
struct question
{
char ask[200];//选择题题目//
char answer[4][80];//选择题选项,每个答案的长度//
int right;//正确答案//
struct question *next;//next是指针类型的成员,
//它指向struct question类型数据(即next所在的结构体类型)
//使用指针类型成员存放下一个结点的地址
//此步骤实现了问题的连续输入输入
};
int menu(void);//声明菜单选择函数
struct question *seek(struct question *seek,long len,long max);//寻找读取答案的位置
struct question *insert(struct question *fst,const struct question *ad);//插入试题
void getquestion(struct question *s);//获取问题,选项,以及正确答案
void savefile(const struct question *a,FILE *sf);//保存最佳答案在文件中//
struct question *loadfile(struct question *b,FILE *lf);//读取题目,将题目添加到列表中
int getanswer(void);//得到答案
int getyouranswer(void);//得到考生答案
void explainquestion(const struct question *q,int n);//统计答对题目数,显示得分
//选择菜单//
int menu(void)
{
int v;
printf("1—添加选择题\n2—回答选择题\n3—退出\n");
scanf("%d",&v);
return v;
}
//seek函数确定一个读取答案的位置,len代表要读取的答案数,max代表列表的长度//
struct question *seek(struct question *seek,long len,long max)
{
int i;
srand(time(NULL));
while(i=rand()%max+len<max);//随机选取一个读题目的位置//
while(i--)
seek=seek->next;//找到指定的位置//
return seek;
}
//向列表中插入试题//
struct question *insert(struct question *fst,const struct question *ad)
{
struct question *newptr=(struct question *)malloc(LEN);//分配新的内存空间//
if (newptr==NULL)
exit(0);
*newptr=*ad;
newptr->next=fst;
return newptr;
}
//获取问题,选项,以及正确答案//
void getquestion(struct question *s)
{
int i=0;
printf("请输入选择题题目:\n");
scanf("%s",s->ask);//指向结构体中的成员//
while(i<4)
{
printf("请输入选项%c的答案:\n",i+'A');
scanf("%s",s->answer[i++]);
}
s->right=getanswer();
}
//试题保存//
void savefile(const struct question *a,FILE *sf)//使用const说明成员函数//
{
fclose(sf);
if((sf=fopen("kstm.dat","w"))==NULL)//以写的方式重新打开文件//
return;
while(a)
{
fwrite(a,sizeof(struct question),1,sf);
a=a->next;
}
}
//从文件中读取题目,将题目添加到列表中//
struct question *loadfile(struct question *b,FILE *lf)
{
struct question temp;
while (fread(&temp,sizeof(struct question),1,lf))
b=insert(b,&temp);
return b;
}

//统计答对题目数,显示得分//
void explainquestion(const struct question *que,int n)
{
int i=0,t=0;
char result[1001],*p=result;
for(i=0;t<n;que=que->next,t++)
{
printf("%s\nA.%s\nB.%s\nC.%s\nD.%s\n\n",que->ask,que->answer[0],que->answer[1],que->answer[2],que->answer[3]);
if((*p=que->right)==(*(p+1)=getyouranswer()))
++i;
p+=2;
}
*p='\0';
printf("\n%-20s%-20s%s\n","标准答案","你的答案","评价");
for(p=result;*p!='\0';p+=2)
printf("%-20c%-20c%s\n",*p,*(p+1),*p==*(p+1)?"正确":"错误");
printf("\n你回答了%d道题,答对%d道题目,得分:%.2f\n\n",n,i,(float)(i*100.00/n));
}
//得到选择题的答案//
int getanswer(void)
{
static int i=1;
int c=0;//必须进行初始化,避免出现偶然性的错误//
while(c<'A'||c>'D')//确保输入的答案是ABCD中的一个//
{
printf("请输第%d题的正确答案:",i);
scanf("%c",&c);
printf("\n");
if(c>96)
c=c-32;//实现小写向大写的转换//
}i++;
return c;
}
int getyouranswer(void)
{
int c=0;//必须进行初始化,避免出现偶然性的错误//
while(c<'A'||c>'D')//确保输入的答案是ABCD中的一个//
{
printf("请输入你的答案:");
scanf("%c",&c);
if(c>96)
c=c-32;//实现小写向大写的转换//
}
return c;
}
main()
{
struct question *start=NULL,temp;
long int choice,line=0,c;
FILE *fp=fopen("kstm.dat","a+");//用'a+'方式打开文件名为'kstm.dat'文件,可添可读//
start=loadfile(start,fp);
printf(" *****欢迎使用此考试系统,请输入你要执行的步骤的编号*****\n");
while((choice=menu())!=3)//如果考生不选3-退出//
if(choice==1)
{
getquestion(&temp);
start=insert(start,&temp);
++line;//统计列表的长度//
}
else if(choice==2)
{
printf("请输入要回答的问题数量:");
scanf("%d",&c);
start=seek(start,c,line);
explainquestion(start,c);
}
savefile(start,fp);
fclose(fp);
return 0;
}