第8周编程总结
| 這個作業要求在哪里 | https://edu.cnblogs.com/campus/zswxy/software-engineering-class2-2018/homework/3074 |
| 我在這個課程的目標是 | 常用的字符串處理函數,指針實現內存動態分配 |
| 這個作業在哪個具體方面幫助我實現目標 | string.h函數,strcpy,strcat應用 |
| 參考文獻 | C語言程序設計第8章 |
函數實現字符串逆序 (15 分)
結隊感想:有些東西靠一個人是不能完成,有時候會陷入一種誤區,沒走出誤區就一直在繞彎,還是要多把自己的疑問和同學一起討論,把問題解決.
本題要求實現一個字符串逆序的簡單函數。
函數接口定義:
函數f對p指向的字符串進行逆序操作。要求函數f中不能定義任何數組,不能調用任何字符串處理函數。
裁判測試程序樣例:
輸入樣例:
Hello World!輸出樣例:
!dlroW olleH實驗代碼
void f( char *p ) {int i=0,a=0,b,c;while(p[i]!='\0')i++;b=i-1;while(a<=b){c=p[a];p[a]=p[b];p[b]=c;a++;b--;}return;}實驗思路:用函數f判斷字符串的結束,并且把字符串進行逆序操作
錯誤截圖:
遇到問題:當我在博客上看了一些解題, 忽略字符串里面有\0作為結束標志
解決方法:把字符串的長度減去1個,此時它的長度等于s[MAXS]
正確截圖:
流程圖:
字符串的連接 (15 分)
本題要求實現一個函數,將兩個字符串連接起來。
函數接口定義:
/* 你的代碼將被嵌在這里 */
輸入樣例:
輸出樣例:
abcdef abcdef實驗代碼
char *str_cat( char *s, char *t ) {s = strcat(s,t);return s;}實驗思路:利用string.h函數的strcat語句,把t中的元素給s
錯誤截圖:
遇到問題:這個題目只要上課聽了,看書也可以寫出來,但是返回值被我給了p
解決方法:把返回的結果改成s,s中才是要輸出的字符串
正確截圖:
流程圖:
輸出學生成績 (20 分)
本題要求編寫程序,根據輸入學生的成績,統計并輸出學生的平均成績、最高成績和最低成績。建議使用動態內存分配來實現。
輸入格式:
輸入第一行首先給出一個正整數N,表示學生的個數。接下來一行給出N個學生的成績,數字間以空格分隔。
輸出格式:
按照以下格式輸出:
結果均保留兩位小數。
輸入樣例:
輸出樣例:
average = 90.00 max = 95.00 min = 85.00代碼
#include<bits/stdc++.h> main() {double *p;int i;double average,min=101,max=0,n,sum;scanf("%lf",&n);if((p=(double *)malloc(n*sizeof(double)))==NULL){ exit(1);}for(i=0;i<n;i++){scanf("%lf",&p[i]);}sum=0;for(i=0;i<n;i++){sum+=p[i];}average=sum/n;printf("average = %.2f\n",average);for(i=0;i<n;i++){if(max<p[i]){max=p[i];}}printf("max = %.2f\n",max);for(i=0;i<n;i++){if(min>p[i]){min=p[i];}}printf("min = %.2f",min);return 0; }實驗思路:根據題目要求定義一個double類型的數組,用for求成績的和和它的平均成績,再到后面用前面學過的知識找出它的最大最小值
錯誤截圖:
遇到問題:出現了編譯錯誤,然后我去百度了一下,它這里還要用到一個#include<stdlib.h>頭文件,然后我又再網上找了一個萬能的頭文件#include<bits/stdc++.h>,它包含了許多的頭文件在內.發現return 0;這里可用free(p);代替,釋放指針
解決方法:輸入一個#include<stdlib.h>或者使用#include<bits/stdc++.h>
正確截圖:
流程圖:
字符串排序 (20 分)
本題要求編寫程序,讀入5個字符串,按由小到大的順序輸出。
輸入格式:
輸入為由空格分隔的5個非空字符串,每個字符串不包括空格、制表符、換行符等空白字符,長度小于80。
輸出格式:
按照以下格式輸出排序后的結果:
每行一個字符串
輸入樣例:
輸出樣例:
After sorted: blue green red white yellow代碼
#include<stdio.h> #include<string.h> int main() {int k;char a[5][80],s[80];for(k=0;k<5;k++){scanf("%s",a[k]);}for(int x=1;x<k;x++)for(int y=0;y<k-x;y++){if(strcmp(a[y],a[y+1])>0)//strcmpy即對字符串的比較{strcpy(s,a[y]);strcpy(a[y],a[y+1]);strcpy(a[y+1],s);}}printf("After sorted:\n");for(int t=0;t<k;t++)printf("%s\n",a[t]);return 0; }實驗思路:定義一個二維字符串數組和一個字符數組,strcmp字符串的比較字符串的大小,strcpy把他們放到s[80]中,輸出s[80]
正確截圖:
流程圖:
計算平均成績 (15 分)
給定N個學生的基本信息,包括學號(由5個數字組成的字符串)、姓名(長度小于10的不包含空白字符的非空字符串)和成績([0,100]區間內的整數),要求計算他們的平均成績,并順序輸出平均線以下的學生名單。
輸入格式:
輸入在一行中給出正整數N(≤10)。隨后N行,每行給出一位學生的信息,格式為“學號 姓名 成績”,中間以空格分隔。
輸出格式:
首先在一行中輸出平均成績,保留2位小數。然后按照輸入順序,每行輸出一位平均線以下的學生的姓名和學號,間隔一個空格。
輸入樣例:
輸出樣例:
80.00 zhang 00001 chen 21987代碼
#include<stdio.h> struct score { char num[10];char name[10];double s; }; int main() {struct score s[1000];int i,n;double average = 0;scanf("%d",&n);for(i=0;i<n;i++){scanf("%s %s %lf",&s[i].num,&s[i].name,&s[i].s);} for(i=0;i<n;i++) {average = average+s[i].s; } average = average/n; printf("%.2f\n",average) ; for(i=0;i<n;i++) {if(s[i].s<average){printf("%s %s\n",s[i].name,s[i].num);} }return 0; }實驗思路:程序首部定義結構類型 num[10] name[10] s,表示學號姓名分數,average用來求平均值,最后比較是否小于平均分,在輸出名字學號
正確截圖:
流程圖:
學習總結:
學習感悟:總會遇到新的問題,要去多看書,多學習,把容易忘記的東西多復習幾次,有些題目就是用現在學的知識和以前的知識拼接起來的,但是要寫出來就要對他們有一定的了解
折線圖
轉載于:https://www.cnblogs.com/I-FEAR-ONLY-TIME/p/10738300.html
總結
- 上一篇: 常用数据库语句(更新)
- 下一篇: gRPC源码分析(c++)