要求一、设计过程

                                                      作业(1)

1.提交列表

6-7 删除字符串中数字字符

2.设计思路(6分)

     (1)主描述题目算法。
         第一步:设出字符char *srt,char*substr;

         第二步:使用for循环语句和if语句,判断是否数字字符;

第三步: 循环寻找或结束语句。
     (2)流程图

主函数调用:

返回主函数:

3.实验代码

void delnum(char *s)
{
int i,m=;
for(i=;*(s+i)!='\0';i++)
{
if(*(s+i)>=''&&*(s+i)<='')
{
}else
{
*(s+m)=*(s+i);
m++;
}
}
*(s+m)='\0';
}
 

4.本题调试过程碰到问题及解决办法。

    
       改正方法:并且符号是两个&&。

     

6-8 统计子串在母串出现的次数

     (1)描述题目算法
         第一步:列出char*str,并使用函数char str[81]="asdasas";
         第二步:使用for语句和if语句统计字符出现字数,令str依次srt+i,str+i+1...; 

         第三步:返回函数。

3.实验代码(2分)   

int fun(char *str,char *substr){
int i,count=;
for(i=;*(str+i)!='\0';i++){
if(*(str+i)==*(substr)){
if(*(str+i+)==*(substr+)){
if(*(str+i+)==*(substr+)){
count++;
}
}
}
}
return count;
}

4.本题调试过程碰到问题及解决办法(4分)

    

       改正方法:‘\0'忘记加\,字符串是以\0为结束标志,找不到\0会越界访问。

      .

6-9 字符串中除首尾字符外的其余字符按降序排列

     (1)描述题目算法
         第一步:设出指针,用外循环控制循环数,num-1次;
         第二步:用for循环和if语句判断字符ASCII大小;

         第三步:判断后交换大小。

3.实验代码

int fun(char *s,int num){
int i,j,k,temp;
for(i=;i<num-;i++){
k=i;
for(j=i+;j<num-;j++){
if((int)(*(s+k))<(int)(*(s+j))){
k=j;
}
}
if(k!=i){
temp=*(s+i);*(s+i)=*(s+k);*(s+k)=temp;
}
}
return ;
}

4.本题调试过程碰到问题及解决办法

     

       改正方法:第一次限制循环未控制在num-1次。

     

7-1 输出学生成绩

     (1)描述题目算法
         第一步:输入学生人数,动态分配;
         第二步:用for循环相加成绩;

         第三步:令max,min,等于数组第一个元素,比较大小,并用for循环交换。

3.实验代码   

 #include <stdio.h>
#include <stdlib.h>
int main()
{
int i,n;
float sum=,average,max,min;
scanf("%d",&n);
float *p=(float *)malloc(n);
for(i=;i<n;i++){
scanf("%f",(p+i));
sum+=*(p+i);
}
min=*(p+);max=*(p+);
for(i=;i<n;i++){
if(min>*(p+i)){
min=*(p+i);
}
if(max<*(p+i)){
max=*(p+i);
}
}
printf("average = %.2f\n",sum/n*);
printf("max = %.2f\n",max);
printf("min = %.2f\n",min);
return ;
}

4.本题调试过程碰到问题及解决办法

     

       错误原因:min=*(p);max=*(p);输出后与列子不同。
       改正方法:min=*(P+0);max=*(p+0);表示依次加。

 作业(2) 

1.提交列表

.

2.设计思路(6分)

 7-1 计算职工工资

(1)描述题目算法。

         第一步:设出变量,使用结构算法;
         第二步:用for循环语句,保证正确输出;

第三步:令实际工资=s1.j+s1.f-s1.z,输出。
 

     (2)流程图

     

3.实验代码   

#include <stdio.h>
struct clerk
{
float j,f,z;
char name[];
}; int main()
{
int i,n;
float pay;
scanf("%d",&n);
struct clerk s1;
for(i=;i<=n;i++)
{
scanf("%s %f %f %f",s1.name,&s1.j,&s1.f,&s1.z);
pay=s1.j+s1.f-s1.z;
printf("%s %.2f\n",s1.name,pay);
}
return ;
}

4.本题调试过程碰到问题及解决办法。   

         错误原因:第一次使用数组的方法,麻烦且没有成功。
       改正方法:使用简单的for循环,数据结构就很容易编写。

7-2 计算平均成绩

      (1)描述题目算法。

         第一步:定义结构;

         第二步:计算平均值 ,输出;         

         第三步:用for循环,if语句,判断每人成绩是否小于平均值;若是。则输出,学生和学号。

3.实验代码 

#include <stdio.h>
struct student
{
char num[];
char name[];
int grade;
double average;
}; int main()
{
int i,N,sum = ;
double average;
scanf("%d",&N);
struct student s[N];
for(i=;i<N;i++)
{
scanf("%s %s %d",s[i].num,s[i].name,&s[i].grade);
sum = sum + s[i].grade;
}
average = (double)(sum/N);
printf("%.2f\n",average);
for(i=;i<N;i++)
{
if(s[i].grade<average)
{
printf("%s %s\n",s[i].name,s[i].num);
}
} return ;
}

4.本题调试过程碰到问题及解决办法。

解决方法:'\n'一直打成'/n',令答案错误。

作业(3)

1.提交列表

2.设计思路(6分)

6-1 按等级统计学生成绩

(1)描述题目算法。

         第一步:列出指针;     

         第二步:用for循环,if语句判断学生成绩是否小于60;

         第三步:count 在每次又小于60的同学,逐渐+1;

         第四步:返回count的值到主函数。

      (2)流程图

3.实验代码   

int set_grade( struct student *p, int n ){
int i,q=;
for(i=;i<n;i++,p++){
if(p->score<){
q++;
}
if((p->score>=)&&(p->score<=)){
p->grade ='A';
}else if((p->score>=)&&(p->score<=)){
p->grade ='B';
}else if((p->score>=)&&(p->score<=)){
p->grade='C';
}else{
p->grade='D';
}
}
return q;
}

4.本题调试过程碰到问题及解决方法。

解决方法:要定义n。

6-2 结构体数组按总分排序

     (1)描述题目算法。
         第一步:列出指针,结构体;
         第二步:用for循环,一个循环第n个人的成绩总数值,一个计算第n个人的成绩总值;

第三步:用冒泡法排序,按总成绩大小排序,交换。

3.实验代码  

void calc(struct student *p,int n){
int i;
for(i=;i<n;i++){
(p+i)->sum=(p+i)->score[]+(p+i)->score[]+(p+i)->score[];
}
}
void sort(struct student *p,int n){
int i,j,t;
struct student temp;
for(i=;i<n-;i++){
t=i;
for(j=i;j<n;j++){
if(((p+t)->sum)<((p+j)->sum)){
t=j;
}
}
if(t!=i){
temp=*(p+i);*(p+i)=*(p+t);*(p+t)=temp;
}
}
}

4.本题调试过程碰到问题及解决办法(4分)

    

       错误原因:if((p+t)->sum)<((p+j)->sum)),少加一个括号。
       改正方法:加上即可。

要求二、学习总结和进度

1、总结两周里所学的知识点有哪些学会了?哪些还没有学会?

在这两周学习了结构和在结构体中使用指针。将结构和两个结构的写法听的很清楚明白并感觉对for循环和if语句又有了更清楚的认识。没有学习明白指针在结构的使用,还是对函数有些苦恼,会尽快弄明白。

2、GIT:https://git.coding.net/GUANCHENG/101.git

3、点评3个同学的本周作业。

  张心悦:http://www.cnblogs.com/zxy980612/p/8696690.html

  丰大为:http://www.cnblogs.com/DavidPark/p/8664273.html

  王姝雯:http://www.cnblogs.com/phsudie/p/8661686.html

4、折线图。

C-语言第二次作业(大一下)的更多相关文章

  1. C语言——第二次作业(2)

    作业要求一 PTA作业的提交列表 作业要求二 题目1.删除字符串中数字字符(函数题) 1.设计思路 - (1)算法 第一步:调用定义的函数. 第二步:定义i=0.j=0,i为原字符数组角标,j为删除后 ...

  2. c++语言第二次作业

    一题目7-1统计学生成绩 1实验代码 #include<stdio.h> int main(void) { int i,n,grade,A,B,C,D,E; A=B=C=D=E=; sca ...

  3. C语言--第二周作业

    ****学习内容总结**** 1.Git和编辑器截图 2.MOOC截图 3.阅读<提问的智慧>感想 读完<提问的智慧>之后,我认为在提问时,要根据以下步骤: 谨慎明确的描述症状 ...

  4. C语言第二次作业 ,

    一:修改错题 1输出带框文字:在屏幕上输出以下3行信息. 将源代码输入编译器 运行程序发现错误 错误信息1: 错误原因:将stido.h拼写错误 改正方法:将stido.h改为stdio.h 错误信息 ...

  5. C语言--第二周作业评分和总结(5班)

    作业链接:https://edu.cnblogs.com/campus/hljkj/CS2017-5/homework/1026 一.评分要求 要求1 阅读指定博客+阅读收获+例子.(5分) 要求2 ...

  6. C语言第二次作业-----顺序结构

    一:改错题 (1)输出指定信息: 将给定源代码输入编译器: 执行编译命令,发现编译器报错,错误信息如下: 经检查,发现源程序将"stdio.h"误拼为"stido.h&q ...

  7. C语言第二周作业

    一.PTA实验作业 题目一:7-1 计算分段函数 1.实验代码 double x,y; scanf("%lf", &x); if(x >= 0){ y=pow(x,0 ...

  8. C语言第二次作业---分支结构

    一.PTA实验作业 题目1:计算分段函数[2] 1.实验代码 double x,y; scanf("%lf",&x); if(x>=0){ y=sqrt(x); } ...

  9. c语言第二次作业2

    ---恢复内容开始--- (一)改错题 1.输出带框文字:在屏幕上输出以下3行信息. 源程序 对源程序进行编译 错误信息1: 错误原因:stdio.h输入错误 改正方法:i和d互换位置 错误信息2: ...

  10. 2018C语言第二次作业

    一.学习内容总结 1.指针是一种数据类型,同样占有空间,其存储的是内存地址: 2.定义指针变量要在变量名之前加“*”字符表示: 3.“&”是取地址运算符,“*”是间接运算符: (注:声名和使用 ...

随机推荐

  1. SQL语句中case函数

    case函数,严格的意义上来讲case函数已经试流程控制语句了,不是简单意义上的函数,不过为了方便,很多人将case函数称为流程控制函数. case函数的一般有两种用法:1.case expressi ...

  2. SVN提交修改时出现:Checksum mismatch

    在使用SVN commit提交修改时,提示Checksum mismatch 问题,提示版本不一致,不能提交,类似于下图. 图片来源于网络,如有侵权,请告知删除. 搜索stackoverflow.co ...

  3. Django加载静态网页模板

    Django加载静态网页模板 步骤: 第一步:在子系统blog根目录下新建模版目录templates,里面新建一个login.html <!DOCTYPE html> <html l ...

  4. BZOJ 2763 飞行路线(分层图最短路)题解

    题意:中文题意不解释... 思路:分层图最短路,我们再开一维用来表示当前用了多少次免费次数,dis[i][j]就表示到达i点用了j次免费的最短路,有点DP的感觉. 当个模板用 参考:分层图最短路 代码 ...

  5. HDU 2544 最短路(最短路&Floyd)题解

    思路:Floyd模板题,注意一下Floyd核心的三个循环,顺序不要变,我们不能把k放在最内层.因为Floyd是通过不断遍历查找是否有更小的两个路径拼起来能比当前小,如果k在最内层,那么我们就会提前算好 ...

  6. 框架-spring入门总结

    框架-spring入门总结 参考: http://www.cnblogs.com/heavenyes/p/3908546.html http://www.cnblogs.com/heavenyes/p ...

  7. Gradle sync failed: Read timed out

    : Gradle sync started : Gradle sync failed: Read timed out Consult IDE log m s ms) 原因是Gradle下载超时 一.下 ...

  8. Tensorflow一些常用基本概念与函数(一)

    1.tensorflow的基本运作 为了快速的熟悉TensorFlow编程,下面从一段简单的代码开始: import tensorflow as tf #定义‘符号’变量,也称为占位符 a = tf. ...

  9. 2018-2019-2 20165332 《网络对抗技术》Exp4 恶意代码分析

    2018-2019-2 20165332 <网络对抗技术>Exp4 恶意代码分析 原理与实践说明 1.实践目标 监控你自己系统的运行状态,看有没有可疑的程序在运行. 分析一个恶意软件,就分 ...

  10. 2-14-2 MySQL数据类型

    MySQL数据类型: 对数据进行分类,针对不同分类进行不同的处理. 1. 使系统能够根据数据类型来操作数据. 2. 预防数据运算时出错. 3. 更有效的利用空间. 数据分类,可以使用最少的存储,来存放 ...