第八周作业
这个作业属于哪个课程 | https://edu.cnblogs.com/campus/zswxy/software-engineering-class1-2018/homework/3076 |
这个作业要求在哪儿 | 动态分布 |
我在这个课程的目标是 | 很多很多,往死学就是了 |
这个课程在哪个方面帮我实现目标 | string语句 |
参考文献 | 课本 |
本题要求实现一个字符串逆序的简单函数。 函数接口定义: void f( char *p ); 函数f对p指向的字符串进行逆序操作。要求函数f中不能定义任何数组,不能调用任何字符串处理函数。 裁判测试程序样例: #include <stdio.h> #define MAXS 20 void f( char *p ); void ReadString( char *s ); /* 由裁判实现,略去不表 */ int main() { char s[MAXS]; ReadString(s); f(s); printf("%s\n", s); return 0; } /* 你的代码将被嵌在这里 */ 输入样例: Hello World! 输出样例: !dlroW olleH
1 实验代码
、void f(char *s) { int len=0; while (s[len++]); len--; int min = 0; int max = len - 1; while (min<max) { char temp = s[min]; s[min] = s[max]; s[max] = temp; min++; max--; } }
2 设计思路
首尾字符交换
3 遇到问提
4 程序远行截图
6-3 字符串的连接 (15 分) 本题要求实现一个函数,将两个字符串连接起来。 函数接口定义: char *str_cat( char *s, char *t ); 函数str_cat应将字符串t复制到字符串s的末端,并且返回字符串s的首地址。 裁判测试程序样例: #include <stdio.h> #include <string.h> #define MAXS 10 char *str_cat( char *s, char *t ); int main() { char *p; char str1[MAXS+MAXS] = {'\0'}, str2[MAXS] = {'\0'}; scanf("%s%s", str1, str2); p = str_cat(str1, str2); printf("%s\n%s\n", p, str1); return 0; } /* 你的代码将被嵌在这里 */ 输入样例: abc def 输出样例: abcdef abcdef
1实验代码
char *str_cat( char*s,char*t) { strcat(s,t); return s; }
2 设计思路
3遇到问题
老师上课讲了
4程序远行截图
本题要求编写程序,根据输入学生的成绩,统计并输出学生的平均成绩、最高成绩和最低成绩。建议使用动态内存分配来实现。 输入格式: 输入第一行首先给出一个正整数N,表示学生的个数。接下来一行给出N个学生的成绩,数字间以空格分隔。 输出格式: 按照以下格式输出: average = 平均成绩 max = 最高成绩 min = 最低成绩 结果均保留两位小数。 输入样例: 3 85 90 95 输出样例: average = 90.00 max = 95.00 min = 85.00
1实验代码
#include<stdio.h> #include<stdlib.h> int main() { int *p; int N,i; float Max,Min,average,sum; scanf("%d",&N); p=(int *)malloc(sizeof(int) *N); for(i=0;i<N;i++) { scanf("%d",p+i); if(i==0) { Max = *(p+i); Min = *(p+i); } else { if(*p+i>Max) Max = *(p+i); if(*(p+i)<Min) Min=*(p+i); } sum += *(p+i); } average=sum / N; printf("average=%.2f\nMax%.2f\nMin%.2f\n",average,Max,Min); free(p); return 0; }
2 设计思路
3 遇到问题
分配动态内存
4运行结果
本题要求编写程序,读入5个字符串,按由小到大的顺序输出。
输入格式:
输入为由空格分隔的5个非空字符串,每个字符串不包括空格、制表符、换行符等空白字符,长度小于80。
输出格式:
按照以下格式输出排序后的结果:
After sorted:
每行一个字符串
输入样例:
red yellow blue green white
输出样例:
After sorted: blue green red white yellow
我的格格变成这样子了没不知道怎么弄
将就将就
。。。/。/
1实验代码
#include<stdio.h>
#include<string.h>
int main(void)
{
int i,j;
char a[5][20], t[20];
for (i = 0; i < 5; i++)
{
scanf("%s",a[i]);
}
for (i = 1; i < 5; i++)
{
for (j =0; j < 5-i ;j++)
if (strcmp(a[j], a[j+1]) > 0)
{
strcpy(t,a[j]);
strcpy(a[j], a[j + 1]);
strcpy(a[j + 1], t);
}
}
printf("After sorted:\n");
for (i = 0; i < 5; i++)
puts(a[i]);
return 0;
}
2设计思路
冒泡排序法
3遇到问题
我写错了
4运行结果