当前位置:首页 > 数据库 > 正文

c语言100个经典例题(c语言经典编程题)

c语言100个经典例题(c语言经典编程题)

大家好,今天来为大家解答c语言100个经典例题这个问题的一些问题点,包括c语言经典编程题也一样很多人还不知道,因此呢,今天就来为大家分析分析,现在让我们一起来看看吧!如...

大家好,今天来为大家解答c语言100个经典例题这个问题的一些问题点,包括c语言经典编程题也一样很多人还不知道,因此呢,今天就来为大家分析分析,现在让我们一起来看看吧!如果解决了您的问题,还望您关注下本站哦,谢谢~

c语言100行简单一点的代码

#include<malloc.h>

#include<stdio.h>

#include<stdlib.h>

#defineLENsizeof(structscorenode)

#defineDEBUG

#include<string.h>

structscorenode

{intnumber;/*学号*/

charname[10];/*姓名*/

floatyuwen;/*语文成绩*/

floatyingyu;/*英语成绩*/

floatshuxue;/*数学成绩*/

structscorenode*next;

};

typedefstructscorenodescore;

intn,k;/*n,k为全局变量,本程序中的函数均可以使用它*/

/*==============================================================================================*/

score*creat2311(void)

/*函数creat2311,功能:创建链表,此函数带回一个指向链表头的指针*/

{

score*head;

score*p1,*p2,*p3,*max;

inti,j;

floatfen;

chart[10];

n=0;

p1=p2=p3=(score*)malloc(LEN);head=p3;/*开辟一个新单元*/

printf("请输入学生资料,输0退出!\n");

repeat1:printf("请输入学生学号(学号应大于0):");/*输入学号,学号应大于0*/

scanf("%d",&p1->number);

while(p1->number<0)

{getchar();

printf("输入错误,请重新输入学生学号:");

scanf("%d",&p1->number);}

/*输入学号为字符或小于0时,程序报错,提示重新输入学号*/

if(p1->number==0)

gotoend;/*当输入的学号为0时,转到末尾,结束创建链表*/

else

{

p3=head;

if(n>0)

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

{if(p1->number!=p3->number)

p3=p3->next;

else

{printf("学号重复,请重输!\n");

gotorepeat1;

/*当输入的学号已经存在,程序报错,返回前面重新输入*/

}

}

}

}

printf("请输入学生姓名:");

scanf("%s",&p1->name);/*输入学生姓名*/

printf("请输入语文成绩(0~100):");/*输入语文成绩,成绩应在0-100*/

scanf("%f",&p1->yuwen);

while(p1->yuwen<0||p1->yuwen>100)

{getchar();

printf("输入错误,请重新输入语文成绩");/*输入错误,重新输入语文成绩直到正确为止*/

scanf("%f",&p1->yuwen);}

printf("请输入英语成绩(0~100):");/*输入英语成绩,成绩应在0-100*/

scanf("%f",&p1->yingyu);

while(p1->yingyu<0||p1->yingyu>100)

{getchar();

printf("输入错误,请重新输入英语成绩");/*输入错误,重新输入英语成绩直到正确为止*/

scanf("%f",&p1->yingyu);}

printf("请输入数学成绩(0~100):");/*输入数学成绩,成绩应在0-100*/

scanf("%f",&p1->shuxue);

while(p1->shuxue<0||p1->shuxue>100)

{getchar();

printf("输入错误,请重新输入数学成绩");

scanf("%f",&p1->shuxue);}/*输入错误,重新输入数学成绩直到正确为止*/

p1=head;

p0=stu;

if(head==NULL)

{head=p0;p0->next=NULL;}/*当原来链表为空时,从首结点开始存放资料*/

else/*原来链表不为空*/

{

if(p1->next==NULL)/*找到原来链表的末尾*/

{

p1->next=p0;

p0->next=NULL;/*将它与新开单元相连接*/

}

else

{

while(p1->next!=NULL)/*还没找到末尾,继续找*/

{

p2=p1;p1=p1->next;

}

p1->next=p0;

p0->next=NULL;

}

}

n=n+1;

p1=head;

p0=stu;

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

{

for(j=i+1;j<=n;j++)

{

max=p1;

p1=p1->next;

if(max->number>p1->number)

{

k=max->number;

max->number=p1->number;

p1->number=k;

/*交换前后结点中的学号值,使得学号大者移到后面的结点中*/

strcpy(t,max->name);

strcpy(max->name,p1->name);

strcpy(p1->name,t);

/*交换前后结点中的姓名,使之与学号相匹配*/

fen=max->yuwen;

max->yuwen=p1->yuwen;

p1->yuwen=fen;

/*交换前后结点中的语文成绩,使之与学号相匹配*/

fen=max->yingyu;

max->yingyu=p1->yingyu;

p1->yingyu=fen;

/*交换前后结点中的英语成绩,使之与学号相匹配*/

fen=max->shuxue;

max->shuxue=p1->shuxue;

p1->shuxue=fen;

/*交换前后结点中的数学成绩,使之与学号相匹配*/

}

}

max=head;p1=head;/*重新使max,p指向链表头*/

}end2:

printf("现在的学生数为:%d个!\n",n);

return(head);

}

/*==============================================================================================*/

/*==============================================================================================*/

score*search2311(score*head)

/*函数search2311,功能:查询学生成绩*/

{intnumber;

score*p1,*p2;

printf("输入要查询的学生的学号,");

scanf("%d",&number);

while(number!=0)

{

if(head==NULL)

{printf("\n没有任何学生资料!\n");return(head);}

printf("-----------------------------------------\n");

printf("|学号\t|姓名\t|语文\t|英语\t|数学\t|\n");

printf("-----------------------------------------\n");/*打印表格域*/

p1=head;

while(number!=p1->number&&p1->next!=NULL)

{p2=p1;p1=p1->next;}

if(number==p1->number)

{printf("|%d\t|%s\t|%.1f\t|%.1f\t|%.1f\t|\n",p1->number,p1->name,p1->yuwen,p1->yingyu,p1->shuxue);

printf("-----------------------------------------\n");}/*打印表格域*/

else

printf("%d不存在此学生!\n",number);

printf("输入要查询的学生的学号,");

scanf("%d",&number);

}

printf("已经退出了!\n");

return(head);}

c语言题目:10名评委给一名比赛选手打分。要求用3个函数实现

#include

#include

inta[100];

intmain()

{

inti,n,x;

intmax=0,min=10000;

printf("请输入几个评委:

");

scanf("%d",&n);

intsum=0;

for(i=1;ia[i])min=a[i];

sum=a[i];

}

sum-=max-min;//减去最高分和最低分(前提评委数大于2)

doubleavg=double(sum)/(n-2);//平均分

min=100000;

for(i=1;ifabs(a[i]-avg))

{

min=fabs(a[i]-avg);

x=i;

}

}

printf("第%d评委与平均分最接近

",x);

return0;

}。

c语言填空题和改错题技巧

以下是一些技巧和建议:

填空题技巧:

1.仔细阅读题目:确保你完全理解题目要求和上下文背景。

2.分析代码逻辑:根据已有的代码和题目要求,推理出缺失部分的代码逻辑。

3.注意语法和语义:填写的代码应符合C语言的语法规则,并且逻辑上与原代码一致。

4.考虑边界情况:考虑特殊情况和边界条件,确保填写的代码在各种情况下都能正确运行。

改错题技巧:

1.仔细分析错误:确定代码中的错误类型,例如语法错误、逻辑错误或者运行时错误。

2.逐行检查代码:从头到尾仔细检查代码,查找可能存在的错误。

3.理解错误提示:如果编译器或调试器提供了错误提示信息,仔细阅读并理解其中的提示,它们可能会指引你找到错误的位置。

4.运行代码进行调试:尝试运行代码,观察程序的行为并使用调试工具进行逐步调试,以便找到错误所在。

5.测试和排除错误:通过输入不同的测试数据,观察代码的输出和行为,逐步排除错误并修复代码。

总的来说,对于填空题和改错题,理解题目要求、熟悉C语言的语法和逻辑,并进行仔细的检查和测试是关键。不断练习和积累经验也能提高解决这类问题的能力。

c语言题目:有13个人围成一圈,顺序排号,报数,凡报到3的就退出,问最后留下来的是原来第几号的那位

#include

intmain()

{

inta[13]={0},*p=&a[12],i=1,*p1;

while(1)

{

do{

p++;

p=a+(p-a)%13;//指针p超出数组范围时自动回0

}

while((*p)==1);//如果成员是被踢出的则继续顺延

if(p1==p)break;elsep1=p;//当只剩一个成员时候跳出

if(i++%3==0)*p=1;//指针指到的成员出局

}

printf("最后剩下第%d个人",p1-a+1);

return0;

}

c语言拍照搜题软件哪个好

大学c语音搜题APP是一款主要为现代的大学生提供的教学软件,特别适合于大学理科类的学生,关于各种计算机,各种机械设计,或者是其他涉及到计算规则C语言方面的教程都可以在这个平台上面进行搜索相关的题目解析,以及各种教程资料。

c语言中值得讨论的话题

C语言作为当今世界最流行和最重要的语言之一,有许多值得讨论的话题,大致可以分为以下几类:

一是学习类,就是讨论如何才能学好C语言,如何解决C语言编程过程中的各类问题等,二是前途类,就是讨论学习C语言可以找到哪些好的工作,可以发挥什么样的作用,岗位薪资等话题。希望以上回答可以帮助到您。

关于c语言100个经典例题的内容到此结束,希望对大家有所帮助。

最新文章