2019年春季学期第五周作业
|这个作业属于哪个课程|C语言程序设计|||
|--------|:-----|
|这个作业要求在哪里|https://edu.cnblogs.com/campus/zswxy/software-engineering-class2-2018/homework/2824|
|我在这个课程的目标是|我希望能够通过这周的学习,了解熟悉字符串的使用|
|这个作业在那个具体方面帮我实现目标|这个作业让我熟悉了字符串的使用|
|参考文献|C语言程序设计|||
第一题:7-1 统计一行文本的单词个数 (15 分)
本题目要求编写程序统计一行字符中单词的个数。所谓“单词”是指连续不含空格的字符串,各单词之间用空格分隔,空格数可以是多个。
输入格式:
输入给出一行字符。
输出格式:
在一行中输出单词个数。
输入样例:
Let's go to room 209.
输出样例:
5
一.代码:
#include<stdio.h>
int main(){
char c,str[222];
int i,count=0,number=0;
gets(str);
for(i=0;;i++)
{
c = str[i];
if(c=='\0')
break;
if(c==' ')number=0;
else if(number == 0)
{
number = 1;
count++;
}
}
printf("%d",count);
return 0;
}
二.流程图
三.问题与方法
问题:刚开始在判断空格时出错了,后来在以空格结尾时也出错了
方法:请搭档帮我检查,找出问题
四.运行截图
第二题:7-1 英文单词排序 (25 分)
本题要求编写程序,输入若干英文单词,对这些单词按长度从小到大排序后输出。如果长度相同,按照输入的顺序不变。
输入格式:
输入为若干英文单词,每行一个,以#作为输入结束标志。其中英文单词总数不超过20个,英文单词为长度小于10的仅由小写英文字母组成的字符串。
输出格式:
输出为排序后的结果,每个单词后面都额外输出一个空格。
输入样例:
blue
red
yellow
green
purple
输出样例:
red blue green yellow purple
一.代码
#include<stdio.h>
#include<string.h>
int main()
{
FILE *op;
op=fopen("Joker.txt","r+");
char str[20][10],t[20],str1[10];
int i,j,n=0;
while(scanf("%s",str1),strcmp("#",str1)!=0)
{
strcpy(str[n],str1);
n++;
}
for(i=0;i<n-1;i++)
for(j=0;j<n-i-1;j++)
{
if(strlen(str[j])>strlen(str[j+1]))
{
strcpy(t,str[j]);
strcpy(str[j],str[j+1]);
strcpy(str[j+1],t);
}
}
for(i=0;i<n;i++)
{
printf("%s ",str[i]);
}
return 0;
}
二.流程图
三.问题与方法
问题:这个题目比较难,我还不是很清楚,是我的搭档带我写出来的,str1变量定义是没有空间大小
方法:问搭档,翻书
四.运行截图
第三题:
一.预习的主要内容:字符串和指针
二.截图:
三.预习中存在的疑惑:
有很多疑惑,很多问题,虽然翻书可以把选择题做出来,但还是有几个题目不是很明白
四.感悟:
结对编程还是很重要的,能从中学到很多东西,也能促进友谊,更能督促自己做题
五.学习进度条:
周\日期 | 这周所花时间 | 代码行数 | 学习内容 | 目前比较困惑的问题 |
---|---|---|---|---|
2.25-3.3 | 四天 | 45 | 数组 | 如何引用数组 |
3.4-3.10 | 四天 | 40 | 文件 | 缓冲文件的工作原理 |
3.12-3.19 | 五天 | 60 | 数组遍历和二维数组 | 数组遍历和二维数组的使用不熟悉 |
3.21-3.22 | 四天 | 70 | 选择排序法和冒泡排序法 | 冒泡排序法不是很明白 |
3.23-3.29 | 四天 | 65 | 字符串 | 字符串的使用和指针 |