6-1 输出月份英文名

1.设计思路

(1)主要描述题目算法

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

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

2.实验代码

int getindex( char *s )
{
int i=0,t=-1;
char *p[7]={"Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"};
for(i=0;i<7;i++)
{
if(*p[i]==*s&&strlen(*p[i])==strlen(*s))
{
return i;
}
}
return t;
}

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

无问题.

6-2 查找星期

1.设计思路

(1)主要描述题目算法

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

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

第三步:否则返回t。

(2)流程图



2.实验代码

int getindex( char *s )
{
int i=0,t=-1;
char *p[7]={"Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"};
for(i=0;i<7;i++)
{
if(strcmp(p[i],s)==0)
{
return i;
}
}
return t;
}

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

无问题.

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

1.设计思路

(1)主要描述题目算法

第一步:定义初值。

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

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

2.实验代码

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

}

}

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

}

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

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

}

###3.本题调试过程碰到问题及解决办法
(无)
###**6-3 链表拼接**
###1.设计思路 (1)主要描述题目算法
第一步:将两个数组的数值赋值在一个数组里。
第二步:将数组进行排序从而得到有序数组。
第三步:把数组各元素赋值回一个新链表,返回链表头结点。
###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. spring基础-01

    IOC : inversion of 缩写, DI:dependency injection 即在调用者中注入被调用者的实例. AOP 面向切面编程,是代理模式的体现.spring默认使用JDK的动态 ...

  2. linux 常用命令总结(一)

    1. 字符串常用命令: 替换: 1). %s/*/*/g 中,替换当前界面的所有符合规则的内容.      2). 替换文件中的字符串内容: find -name '要查找的文件名' | xargs ...

  3. P2831 愤怒的小鸟(状压dp)

    P2831 愤怒的小鸟 我们先预处理出每个猪两两之间(设为$u,v$)和原点三点确定的抛物线(当两只猪横坐标相等时显然无解) 处理出$u,v$确定的抛物线一共可以经过多少点,记为$lines[u][v ...

  4. 初识PHP(三)面向对象特性

    PHP5开始支持面向对象的编程方式.PHP的面向对象编程方法和别的语言区别不大,下面对PHP面向编程基本语法进行简单记录. 一.声明对象 声明方法: class Say{ public functio ...

  5. java读取pdf总结

    第三方软件 1.pdfbox PDFBox 0.7.3.PDFBox是一个开源的对pdf文件进行操作的库. PDFBox-0.7.3.jar加入classpath.同时FontBox1.0.jar加入 ...

  6. 在MyEclise中使用自己安装的tomcat

    ·将Tomcat配置到MyEclipse中 1.在MyEclipse中打开Window子选项Preferences: 2.在Preferences面板中,点击左边选项中的MyEclipse,找到Ser ...

  7. Codeforces Round #319 (Div. 2) C. Vasya and Petya's Game 数学

    C. Vasya and Petya's Game time limit per test 1 second memory limit per test 256 megabytes input sta ...

  8. 上海仪电Azure Stack技术深入浅出系列1:谈Azure Stack在私有云/混合云生态中的定位

    2.2 Azure Stack Azure Stack到2017年7月才提供GA版本,但目前还是可以通过技术预览版了解该技术.Azure Stack本质上是核心Azure服务的一个私有实例. Micr ...

  9. MySQL —— 基本查询方法

    MySQL —— 简单查询与按条件查询 在MySQL中从数据表中查询数据的基本语句时select语句.  select语句基本语法格式:      select 查询内容       from 表名  ...

  10. spring boot: 输出json

    spring boot:  输出json 注意:关闭java的Terminate后,在重新启动,否则报错 app.java启动配置 package com.muyang.boot1; import o ...