这个作业属于那个课程 C语言程序设计II
这个作业要求在哪里 这里
我在这个课程的目标是 能按自己的想法解出题目
这个作业在那个具体方面帮助我实现目标 能朝着软件工程师方向发展
参考文献与网址 C语言程序设计II(第三版) C语言的教学

题目一

本题要求实现一个函数,用于计算有n个元素的指针数组s中最长的字符串的长度。

函数接口定义:

int max_len( char *s[], int n );

其中n个字符串存储在s[]中,函数max_len应返回其中最长字符串的长度。

裁判测试程序样例:

include <stdio.h>

include <string.h>

include <stdlib.h>

define MAXN 10

define MAXS 20

int max_len( char *s[], int n );

int main()

{

int i, n;

char *string[MAXN] = {NULL};

scanf("%d", &n);
for(i = 0; i < n; i++) {
string[i] = (char *)malloc(sizeof(char)*MAXS);
scanf("%s", string[i]);
}
printf("%d\n", max_len(string, n)); return 0;

}

/* 你的代码将被嵌在这里 */

输入样例:

4

blue

yellow

red

green

输出样例:

6

我的代码

int max_len( char *s[], int n ){
int max=0;
int i,j; for(i=0;i<n;i++){
if(strlen(s[max])<strlen(s[i])){
max=i;
}
}
return strlen(s[max]);
}

解题流程图

遇到的问题与解决办法

题目没有遇见要写上来的大问题

运行结果截图

题目二

本题要求实现一个函数,统计学生学号链表中专业为计算机的学生人数。链表结点定义如下:

struct ListNode {

char code[8];

struct ListNode *next;

};

这里学生的学号共7位数字,其中第2、3位是专业编号。计算机专业的编号为02。

函数接口定义:

int countcs( struct ListNode *head );

其中head是用户传入的学生学号链表的头指针;函数countcs统计并返回head链表中专业为计算机的学生人数。

裁判测试程序样例:

include <stdio.h>

include <stdlib.h>

include <string.h>

struct ListNode {

char code[8];

struct ListNode *next;

};

struct ListNode createlist(); /裁判实现,细节不表*/

int countcs( struct ListNode *head );

int main()

{

struct ListNode *head;

head = createlist();
printf("%d\n", countcs(head)); return 0;

}

/* 你的代码将被嵌在这里 */

输入样例:

1021202

2022310

8102134

1030912

3110203

4021205

输出样例:

3

我的代码

int countcs( struct ListNode *head )
{
int num = 0;
struct ListNode *p = head;
while(p != NULL)
{
if(p->code[1] == '0' && p->code[2] == '2')
num++;
p = p->next;
}
return num;
}

解题流程图

遇到的问题与解决办法

题目中规中矩,没有太大的问题哪像上一周作业

运行结果截图

题目三

本题要求实现两个函数,分别将读入的数据存储为单链表、将链表中偶数值的结点删除。链表结点定义如下:

struct ListNode {

int data;

struct ListNode *next;

};

函数接口定义:

struct ListNode *createlist();

struct ListNode *deleteeven( struct ListNode *head );

函数createlist从标准输入读入一系列正整数,按照读入顺序建立单链表。当读到−1时表示输入结束,函数应返回指向单链表头结点的指针。

函数deleteeven将单链表head中偶数值的结点删除,返回结果链表的头指针。

裁判测试程序样例:

include <stdio.h>

include <stdlib.h>

struct ListNode {

int data;

struct ListNode *next;

};

struct ListNode *createlist();

struct ListNode *deleteeven( struct ListNode *head );

void printlist( struct ListNode *head )

{

struct ListNode *p = head;

while (p) {

printf("%d ", p->data);

p = p->next;

}

printf("\n");

}

int main()

{

struct ListNode *head;

head = createlist();
head = deleteeven(head);
printlist(head); return 0;

}

/* 你的代码将被嵌在这里 */

输入样例:

1 2 2 3 4 5 6 7 -1

输出样例:

1 3 5 7

我的代码

struct ListNode *createlist(){
struct ListNode * p ,*head=NULL,*tail;
int size = sizeof (struct ListNode);
int num;
scanf("%d",&num);
while(num!=-1)
{ p=(struct ListNode *) malloc(size);
p->data = num; if(head==NULL){
head=p;
tail=p;
}
else {
tail->next = p;
}
tail = p; scanf("%d",&num);
}
p->next=NULL; return head; }
struct ListNode *deleteeven( struct ListNode *head ){
struct ListNode * ptr,*ptr1,*ptr2; while(head && head->data %2 ==0){
ptr1=head;
head = head->next;
free(ptr1);
}
ptr1=head;
while(ptr1 && ptr1 ->next !=NULL)
{
while(ptr1->next && ptr1->next->data%2==0)
{ //直接跳过要删除的那一部分
ptr2=ptr1->next;
ptr1->next=ptr2->next;
}
ptr1=ptr1->next;
}
return head;
}

解题流程图

遇到的问题与解决办法

这个题问题蛮多,我可能需要重写了,难度比较大

运行结果截图

时间 代码行数 这周所花的时间 学到的知识点简介 目前比较疑惑的问题
3/2-3/19 35 两天 通过代码读取文件里的数据,并且在屏幕上打印 为什么文件的使用还要进行关闭
3/9-3/19 65 三十分钟 没有学到任何知识点 想知道指针与数组之间的内在联系
3/19-3/22 186 五个小时 二维数组的用法加上二分法找元素 需要多打代码多多练习
3/22-3/28 31 一天 字符串的使用 数组排序的内部原理
3/28-4/5 108 一天 指针初步 行参与实参如何相互影响
4/5-4/11 62 一天 熟练指针 指针实际应用的问题
4/11-4/19 182 两天 会使用struct进行编码 为什么不能用赋值表达式直接对数组赋值
4/19- 4/26 126 三天 对结构体的使用更加得心应手 结构定义形式的具体影响是什么
5/6-5/10 189 三天 宏定义的初步体验 如何使用函数递归解决问题
5/10-5/17 65 两天 二级指针,指针数组分别是什么 指向函数的指针的意义是什么

所在小组想要开发的项目的名称和目标:

“地表最强游戏开发组” fly bird 希望能提升自己实力的同时,多多见识

项目主体功能的描述:

暂时不对外公布

现阶段已做的准备工作:

正在积极分配工作与调度资源,待后续

小组成员名单和进度安排:

钟子鸣 20188*** 待定

李雪 20188*** 待定

阳虎材 20188*** 待定

2019春第十二周作业Compile Summarize的更多相关文章

  1. 2019-2020-1 20199329《Linux内核原理与分析》第十二周作业

    <Linux内核原理与分析>第十二周作业 一.本周内容概述: 通过编程理解 Set-UID 的运行机制与安全问题 完成实验楼上的<SET-UID程序漏洞实验> 二.本周学习内容 ...

  2. 2017-2018-1 《Linux内核原理与设计》第十二周作业

    <linux内核原理与设计>第十二周作业 Sql注入基础原理介绍 分组: 和20179215袁琳完成实验 一.实验说明   SQL注入攻击通过构建特殊的输入作为参数传入Web应用程序,而这 ...

  3. 第十二周作业_PSP总结报告

    回顾1 (1)回想一下你曾经对计算机专业的畅想 当初你是如何做出选择计算机专业的决定的?经过一个学期,你的看法改变了么,为什么? 你认为过去接触到的课程是否符合你对计算机专业的期待,为什么?经过一个学 ...

  4. 2019春第十周作业Compile Summarize

    这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能够对C语言的编写更加得心应手 这个作业在那个具体方面帮助我实现目标 结构体更进一步 参考文献与网址 C语言 ...

  5. 2019春第九周作业Compile Summarize

    这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 这里 我在这个课程的目标是 能更加进一步的够熟练掌握指针的用法 这个作业在那个具体方面帮助我实现目标 能解更多的题 参考文献与网址 C语言 ...

  6. 2019春第八周作业Compile Summarize

    这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能更加进一步的够熟练掌握指针的用法 这个作业在那个具体方面帮助我实现目标 指针对于高阶题目的做法 参考文献与 ...

  7. 2019春第七周作业Compile Summarize

    这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能更加进一步的够熟练掌握指针的用法 这个作业在那个具体方面帮助我实现目标 指针对于基础题目的做法 参考文献与 ...

  8. 2019春第六周作业Compile Summarize

    这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能够熟练掌握指针的用法 这个作业在那个具体方面帮助我实现目标 对指针的使用更加得心应手 参考文献与网址 C语 ...

  9. 2019春第五周作业Compile Summarize

    这个作业属于哪个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能够精通关于数组内部运作原理 这个作业在哪个具体方面帮助我实现目标 如何输出一行的连续字符 参考文献与网址 ...

随机推荐

  1. CentOS 7 查看硬盘情况

    用命令: lsblk                                  查看分区和磁盘 df -h                                        查看整 ...

  2. Peakvue和自相关技术轴承诊断

    什么是应力波 应力波产生于“金属与金属相互碰撞的事件” 加速度传感器捕捉含有具有短时特性应力波的轴承振动信号 应力波是一种非常短暂的连续的脉冲信号, 通常在百万分之一秒到千分之一秒的区间范围内, 它是 ...

  3. qt02 textEdit

    1.向QTextEdit中当前光标位置添加一行字符串message ui.messageTextEdit->textCursor().insertText(message+"\n&qu ...

  4. python List 常用方法

    list是python常用的数据类型,属于可变的数据类型.用[]表示,里面的元素用','隔开,并且里面的元素类型可以不同,对于每个元素,list都有一个索引一一对应,第一个元素的索引是0,第二个是1, ...

  5. [CF1208D] Restore Permutation

    传送门 题意:有一个长为\(n\)的排列\(p\),设\(S_i=\sum_{j=1}^{i-1}p_j\cdot[p_j<p_i]\),给出\(S\),要求还原出\(p\).保证有解,\(n\ ...

  6. 【转载】 原生js判断某个元素是否滚动到底部

    document.querySelector('.content').addEventListener('scroll',function () { //读取内容区域的真实高度(滚动条高) // co ...

  7. axios中put和patch的区别(都是update , put是需要提交整个对象资源,patch是可以修改局部)

    patch方法用来更新局部资源,这句话我们该如何理解? 假设我们有一个UserInfo,里面有userId, userName, userGender等10个字段.可你的编辑功能因为需求,在某个特别的 ...

  8. python-登录保持

     cookies.Session import requests url1="http://127.0.0.1:5000/login" url2="http://127. ...

  9. 使用 flex 弹性布局 ,相关教程记录

    一.Flex布局是什么? Flex是Flexible Box的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性. 任何一个容器都可以指定为Flex布局. .box1{ dis ...

  10. jQuery 遍历 - 同胞(siblings)

    同胞拥有相同的父元素. 通过 jQuery,您能够在 DOM 树中遍历元素的同胞元素. 在 DOM 树中水平遍历 有许多有用的方法让我们在 DOM 树进行水平遍历: siblings() next() ...