6-1 输出月份英文名

1.设计思路

(1)主要描述题目算法

第一步:先定义一个指针数组。

第二步:根据for循环判断月份并返还月份字数。

2.实验代码

  1. int getindex( char *s )
  2. {
  3. int i=0,t=-1;
  4. char *p[7]={"Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"};
  5. for(i=0;i<7;i++)
  6. {
  7. if(*p[i]==*s&&strlen(*p[i])==strlen(*s))
  8. {
  9. return i;
  10. }
  11. }
  12. return t;
  13. }

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

无问题.

6-2 查找星期

1.设计思路

(1)主要描述题目算法

第一步:定义一个字符指针数组。

第二步:用循环和条件语句判断这个数是否等于0。等于就返回i。

第三步:否则返回t。

(2)流程图



2.实验代码

  1. int getindex( char *s )
  2. {
  3. int i=0,t=-1;
  4. char *p[7]={"Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"};
  5. for(i=0;i<7;i++)
  6. {
  7. if(strcmp(p[i],s)==0)
  8. {
  9. return i;
  10. }
  11. }
  12. return t;
  13. }

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

无问题.

6-3 计算最长的字符串长度

1.设计思路

(1)主要描述题目算法

第一步:定义初值。

第二步:根据循环和判断来判断大小。

第三步:返回最长字符串的字符返回字数。

2.实验代码

  1. int max_len( char *s[], int n )
  2. {
  3. int i,t=0;
  4. for(i=0;i<n;i++)
  5. {
  6. if(strlen(s[i])>strlen(s[t]))
  7. {
  8. t=i;
  9. }
  10. }
  11. return strlen(s[t]);
  12. }```
  13. ###3.本题调试过程碰到问题及解决办法
  14. 无。
  15. ###**6-4 指定位置输出字符串**
  16. ###1.设计思路
  17. (1)主要描述题目算法
  18. 第一步:定义初值t,g,mark,flag。
  19. 第二步:根据判断结果不同标记成不同的数值。
  20. 第三步:根据不同条件了来返回其中的字符串。
  21. ###2.实验代码

char match( char s, char ch1, char ch2 )

{

int i=0,j=0,t=1,g=1,mark,flag;

for(i=0;;i++)

{ if(
(s+i)=='\0')

{break;

}

if(
(s+i)ch1&&t!=0)

{t=0;

mark=i;}

if(*(s+i)ch2)

{g=0;

flag=i;

}

}

if(t1)

{

printf("\n");

*s='\0';

return s;

}

if(t!=1&&g0)

{

for(j=mark;;j++)

{

if((s+j)=='\0')

{break;

}

printf("%c",
(s+j));

if(*(s+j)ch2)

{ printf("\n");

return (s+mark);

}

}

}

if(t!=1&&g1)

{

printf("%s\n",(s+mark));

return (s+mark);

}

}

  1. ###3.本题调试过程碰到问题及解决办法
  2. 无。
  3. ###**6-1 奇数值结点链表**
  4. ###1.设计思路
  5. (1)主要描述题目算法
  6. 第一步:创建2个新的链表。
  7. 第二步:根据所给链表的奇偶性不同将其给不同的链表。
  8. 第三步:返回2个链表的头结点。
  9. ###2.实验代码

struct ListNode readlist()

{

int data;

struct ListNode head=NULL;

struct ListNode p;

while(scanf("%d",&data)&&data!=-1)

{

struct ListNode q=(struct ListNode)malloc(sizeof(struct ListNode));

if(q!=NULL)

{

q->data=data;

q->next=NULL;

}

else exit(1);

if(head!=NULL)

{

p->next=q;

}

else head=q;

p=q;

}

return head;

}

struct ListNode getodd( struct ListNode **L )

{

struct ListNode head0=NULL,head1=NULL,
p0,
p1;

while((
L)!=NULL)

{

int data=(
L)->data;

struct ListNode q=(struct ListNode)malloc(sizeof(struct ListNode));

if(data%2)

{

if(q!=NULL)

{

q->data=data;

q->next=NULL;

}

else exit(1);

if(head1!=NULL)

{

p1->next=q;

}

else head1=q;

p1=q;

}

else

{

if(q!=NULL)

{

q->data=data;

q->next=NULL;

}

else exit(1);

if(head0!=NULL)

{

p0->next=q;

}

else head0=q;

p0=q;

}

L=(L)->next;

}

*L=head0;

return head1;

}

  1. ###3.本题调试过程碰到问题及解决办法

  2. ###**6-2 学生成绩链表处理**
  3. ###1.设计思路
  4. (1)主要描述题目算法
  5. 第一步:建立一个链表利用循环来进行赋值。
  6. 第二步:输入条件值历链表,对每个低于条件值的节点进行删除。
  7. 第三步:返回删除操作后的链表头结点。
  8. (2)流程图
  9. ![](https://images2018.cnblogs.com/blog/1239182/201804/1239182-20180422224306018-136759193.png)
  10. ![](https://images2018.cnblogs.com/blog/1239182/201804/1239182-20180422224319506-517815500.png)
  11. ![](https://images2018.cnblogs.com/blog/1239182/201804/1239182-20180422224329335-1376048956.png)
  12. ###2.实验代码

struct stud_node *createlist()

{

struct stud_node *head, *tail, *q;

head = tail = NULL;

int num;

scanf ("%d", &num);

while (num != 0)

{

q = (struct stud_node *)malloc (sizeof (struct stud_node));

scanf ("%s %d", q->name, &q->score);

q->num = num;

q->next = NULL;

if (head == NULL)

head = q;

else

tail->next = q;

tail = q;

scanf ("%d", &num);

}

return head;

}

struct stud_node *deletelist( struct stud_node *head, int min_score )

{

struct stud_node *ptr1, *ptr2;

while (head != NULL && head->score < min_score)

{

ptr2 = head;

head = head->next;

free(ptr2);

}

if (head == NULL)

return NULL;

ptr1 = head;

ptr2 = head->next;

while (ptr2 != NULL)

{

if (ptr2->score < min_score) {

ptr1->next = ptr2->next;

free(ptr2);

}

else

ptr1 = ptr2;

ptr2 = ptr1->next;

}

return head;

}

  1. ###3.本题调试过程碰到问题及解决办法
  2. (无)
  3. ###**6-3 链表拼接**
  4. ###1.设计思路
  5. (1)主要描述题目算法
  6. 第一步:将两个数组的数值赋值在一个数组里。
  7. 第二步:将数组进行排序从而得到有序数组。
  8. 第三步:把数组各元素赋值回一个新链表,返回链表头结点。
  9. ###2.实验代码

struct ListNode *mergelists(struct ListNode *list1, struct ListNode *list2)

{

int num = 0;

int temp[100];

struct ListNode *p = list1;

while(p != NULL)

{

temp[num] = p->data;

num++;

p = p->next;

}

p = list2;

while(p != NULL)

{

temp[num] = p->data;

num++;

p = p->next;

}

int i,j;

for(i = 0; i < num; i++)

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

{

if(temp[i] > temp[j])

{

int t;

t = temp[i];

temp[i] = temp[j];

temp[j] = t;

}

}

struct ListNode *newlist = NULL;

struct ListNode *endlist = NULL;

struct ListNode *q;

for(i = 0; i < num; i++)

{

q = (struct ListNode *)malloc(sizeof(struct ListNode));

q->data = temp[i];

if(newlist == NULL)

{

newlist = q;

newlist->next = NULL;

}

if(endlist != NULL)

{

endlist->next = q;

}

endlist = q;

endlist->next = NULL;

}

return newlist;

}```

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

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

这两周我学会了指针数组,指向指针的指针 ,用指针数组处理多个字符串,命令行参数,指针作为函数的返回值,链表 ,链表的概念。

链表的常用操作###2、将PTA作业的源代码使用git提交到托管平台上,要求给出上传成功截图和你的git地址。请注意git地址应是类似



https://git.coding.net/yangzhiqun/cfsafa.git

2018c语言第3次作业的更多相关文章

  1. 2018c语言第1次作业

    6-1 计算两数的和与差 1.设计思路 (1)主要描述题目算法 第一步:把两个数的加减法分别赋给psum和pdiff. 第二步:通过psum和pdiff的地址把值传回主函数. (2)流程图.(无) 2 ...

  2. 2018C语言第三次作业

    要求一 2.struct sk{int a; char *str)}*p;   p->str++ 中的++ 加向? ++加向srt的地址. 要求二 题目1-计算平均成绩 1.设计思路 (1)主要 ...

  3. 2018c语言第2次作业

    1 删除字符串中数字字符 1.设计思路 (1)主要描述题目算法 第一步:先用for循环比较每个数是否符合删除条件. 第二步:如果符合就把这个数利用交换把这个数提前一位. 2.实验代码 void del ...

  4. 关于C语言的问卷调查(作业三)

    1.你对自己的未来有什么规划?做了哪些准备? 答:我对我未来的规划就是希望能够学有所用,将来可以从事有关IT方面的,跟自己的专业对口.为此现在我需要多看一些和这个专业有关的书籍,自学一些知识,多些一些 ...

  5. 网络1711班 C语言第四次作业批改总结

    网络1711班 C语言第四次作业批改总结 助教有话说(写在前面) 近来,有同学跟老师和助教们反映:博客作业太多太麻烦,而且对编程能力提高似乎没什么帮助?在这里我要谈一谈我的感想. 博客作业的意义? 首 ...

  6. 网络1711班 C语言第七次作业批改总结

    网络1711班 C语言第七次作业批改总结 1.本次作业评分细则 1.1 基本要求(1分) 按时交 - 有分 未交 - 0分 迟交一周以上 - 倒扣本次作业分数 抄袭 - 0分 泛泛而谈(最多七分) 1 ...

  7. 网络1711班 C语言第八次作业批改总结

    网络1711班 C语言第七次作业批改总结 最近在忙一些琐事,没能及时批改大家的作业,连续两次作业总结也没有很用心写,在这要给大家say sorry. 1.本次作业评分细则 1.1 基本要求(1分) 按 ...

  8. C语言程序设计第二次作业--顺序结构

    C语言程序设计第二次作业--顺序结构 1.输出带框文字:在屏幕上输出以下3行信息. ************* Welcome ************* 源程序 #include <stido ...

  9. 跨语言调用Hangfire定时作业服务

    跨语言调用Hangfire定时作业服务 背景 Hangfire允许您以非常简单但可靠的方式执行后台定时任务的工作.内置对任务的可视化操作.非常方便. 但令人遗憾的是普遍都是业务代码和hagnfire服 ...

随机推荐

  1. docker——安全防护与配置

    Docker是基于Linux操作系统实现的应用虚拟化.运行在容器内的进程,跟运行在本地系统的进程本质上并无区别,配置不合适的安全策略将可能给本地系统带来安全风险,因此,Docker的安全性在生产环境中 ...

  2. Django小项目简单BBS论坛

    开发一个简单的BBS论坛 项目需求: 1 整体参考"抽屉新热榜" + "虎嗅网" 2 实现不同论坛版块 3 帖子列表展示 4 帖子评论数.点赞数展示 5 在线用 ...

  3. 6.3 Controllers -- Managing Dependencies Between Controllers

    1. 有时候,特别是当嵌套资源的时候,我们需要两个controllers之间的某种连接.让我们拿这个router当做例子: app/router.js var Router = Ember.Route ...

  4. NodeJS学习笔记五

    Promise简介 所谓Promise,就是一个对象,用来传递异步操作的消息. Promise对象有以下两个特点. (1)对象的状态不受外界影响.Promise对象代表一个异步操作,有三种状态:Pen ...

  5. (9)SpriteFrameCache和TextureCache

    简介 SpriteFrameCache 主要服务于多张碎图合并出来的纹理图片.这种纹理在一张大图中包含了多张小图,直接通过TextureCache引用会有诸多不便,因而衍生出来精灵框帧的处理方式,即把 ...

  6. Java集合转有类型的数组之toArray(T[] a)

    在java变成中慎用强制类型转换,尽量使用类自带的转换函数或泛型.先看一行代码 错误方法: String[] array= (String[]) list.toArray(); 如果list中存放的是 ...

  7. 20145319 《网络渗透》Adobe阅读器渗透攻击

    20145319 <网络渗透>Adobe阅读器渗透攻击 一 实验内容 初步掌握平台matesploit的使用 有了初步完成渗透操作的思路 本次攻击对象:windows xp sp3  Ad ...

  8. linux下 ip指令

    目录 Network ip command Command :ip 简介 内容 Network ip command Command :ip 简介 ip 是個指令喔!並不是那個 TCP/IP 的 IP ...

  9. 如何把本地git仓库托管到码云上

    提交代码到本地git仓库 git init git status git add . git status git commit -m "init my project"     ...

  10. Stub学习

    RPC RPC(Remote Procedure Call)就是某台主机A(一般为client)像调用本地的过程一样去调用另一台主机B(一般为server)上的某个过程.RPC代码可能长成这个样子: ...