2019春第十二周作业Compile Summarize
| 这个作业属于那个课程 | 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的更多相关文章
- 2019-2020-1 20199329《Linux内核原理与分析》第十二周作业
<Linux内核原理与分析>第十二周作业 一.本周内容概述: 通过编程理解 Set-UID 的运行机制与安全问题 完成实验楼上的<SET-UID程序漏洞实验> 二.本周学习内容 ...
- 2017-2018-1 《Linux内核原理与设计》第十二周作业
<linux内核原理与设计>第十二周作业 Sql注入基础原理介绍 分组: 和20179215袁琳完成实验 一.实验说明 SQL注入攻击通过构建特殊的输入作为参数传入Web应用程序,而这 ...
- 第十二周作业_PSP总结报告
回顾1 (1)回想一下你曾经对计算机专业的畅想 当初你是如何做出选择计算机专业的决定的?经过一个学期,你的看法改变了么,为什么? 你认为过去接触到的课程是否符合你对计算机专业的期待,为什么?经过一个学 ...
- 2019春第十周作业Compile Summarize
这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能够对C语言的编写更加得心应手 这个作业在那个具体方面帮助我实现目标 结构体更进一步 参考文献与网址 C语言 ...
- 2019春第九周作业Compile Summarize
这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 这里 我在这个课程的目标是 能更加进一步的够熟练掌握指针的用法 这个作业在那个具体方面帮助我实现目标 能解更多的题 参考文献与网址 C语言 ...
- 2019春第八周作业Compile Summarize
这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能更加进一步的够熟练掌握指针的用法 这个作业在那个具体方面帮助我实现目标 指针对于高阶题目的做法 参考文献与 ...
- 2019春第七周作业Compile Summarize
这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能更加进一步的够熟练掌握指针的用法 这个作业在那个具体方面帮助我实现目标 指针对于基础题目的做法 参考文献与 ...
- 2019春第六周作业Compile Summarize
这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能够熟练掌握指针的用法 这个作业在那个具体方面帮助我实现目标 对指针的使用更加得心应手 参考文献与网址 C语 ...
- 2019春第五周作业Compile Summarize
这个作业属于哪个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能够精通关于数组内部运作原理 这个作业在哪个具体方面帮助我实现目标 如何输出一行的连续字符 参考文献与网址 ...
随机推荐
- CentOS7搭建FastDFS+Nginx
1. FastDFS 介绍 FastDFS是一个开源的分布式文件系统,她对文件进行管理,功能包括:文件存储.文件同步.文件访问(文件上传.文件下载)等,解决了大容量存储和负载均衡的问题.特别适合以文件 ...
- 013-linux系统管理——系统资源查看
linux系统管理——系统资源查看 ############# vmstat 命令 监控系统资源 ############# vmstat [刷新时间 刷新次数] [root@zabbix ~]# v ...
- Azure IoT 技术研究系列4
上两篇博文中,我们介绍了将设备注册到Azure IoT Hub,设备到云.云到设备之间的通信: Azure IoT 技术研究系列2-设备注册到Azure IoT Hub Azure IoT 技术研究系 ...
- Tengine + Lua + GraphicsMagick 实现图片自动裁剪/缩放
http://my.oschina.net/eduosi/blog/169606
- 【前端】CSS基础
3种html中设置css的方法: head中style标签 head中link标签rel属性.href后跟css文件目录 在需要使用css样式的标签添加style属性 1.CSS选择器 #id值 .c ...
- vue-cli3.0配置
仅在项目根目录中新建vue.config.js文件即可,部分配置如下 module.exports = { // 基本路径 baseUrl: '/', // 输出文件目录 outputDir: 'di ...
- HTTP content-type及POST提交数据方式
Content-Type(内容类型),一般指网页中存在的Content-Type,用于定义网络文件的类型和网页的编码,决定浏览器将以什么形式.什么编码读取这个文件,这也是一些网页点击的结果却是一个文件 ...
- ExoPlayer + 边缓存边播放
在此基础上改动:https://www.cnblogs.com/candyzhmm/p/9957928.html private void openPlayer(String videoUrl) { ...
- Oulipo【Hash】
Oulipo Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 45515 Accepted: 18181 Descript ...
- 有关于TreeSet的自我理解
TreeSet是依靠TreeMap来实现的. TreeSet是一个有序集合,TreeSet中的元素将按照升序排列,缺省是按照自然排序进行排列,意味着TreeSet中的元素要实现Comparable接口 ...