C语言博客作业--字符数组
一、PTA实验作业
题目1:7-1 字符串转换成十进制整数
1. 本题PTA提交列表
2. 设计思路
3.代码截图
4.本题调试过程碰到问题及PTA提交列表情况说明。
- 这个问题我看了好久,试了很多的的错误点,答案和我预料的一样,所以我重新看了一遍题目,发现曲解了题意
把第一个十六进制字符之前存在字符“-”理解成第一个十六进制字符前一个存在字符“-”
题目2:7-7 删除字符串中的子串
1. 本题PTA提交列表
2. 设计思路
* 定义 i,j,k用于循环,count用于计数,s用于求子串的长度,s1=1,n=0; //i,j,k用于循环
定义The_main_string[81];并且为0
定义substring[81];并且为0
* 输入主串和子串用gets(),并且s=strlen(substring);
* for循环,进入下一步
s1等于n;
* for循环从i=0,直至主串为0,结束后i自增,进入下一步
count=0
* for循环j等于i,k等于0;直至主串不等于子串;结束后j自增,k自增
count自增
* 如果count等于子串长度s,那么对应主串的j-s+1个为0,且将主串j+1剪切过去,并且n++
end
end
* 如果s1等于n,退出循环
* 输出主串
3.代码截图
4.本题调试过程碰到问题及PTA提交列表情况说明。
对于这种情况,我直接将输出了几个值,在纸上重新模拟了程序运行的过程,发现其中有一些算法不合理,就改善了一下
题目3:7-20 指定位置输出字符串
1. 本题PTA提交列表
2. 设计思路
* 定义ij由于循环,n,数组d用于记录下标,字符数组a,字符形bc
* 用gets输出a ,输出b,c
* for i为0,直至a【i】为0进入下一步,i自增
如果a[i]等于b,d【j++】=i
如果a[i]等于c,n=i;
end
* 输出a[0]到n数组a的值
3.代码截图
4.本题调试过程碰到问题及PTA提交列表情况说明。
本题用来一个printf语句来查看遇到b与遇到c的下标,刚开始并没有n变量,后来发现当如果是112211,1,2
这样子的输入,下标会变换,所以用n来记录与才最后相等的下标
二、截图本周题目集的PTA最后排名。
三、同学代码结对互评
我的代码
杰伟的代码
- 我和他的思路的一样,代码也足够简洁。
- 其中在覆盖子串这一问题上我是靠调用库函数中的剪切,杰伟是利用循环左移,这两种方法看个人习惯吧
四、本周学习总结
1.你学会了什么?
- 我学好了指针,其中也明白之前不懂的内存的问题,就是一个变量一个地址,地址的所在地也可以用指针来存放,指针对于的
地址也可以知道 - 我也会学会用新的库函数的复制剪切
1.1指针变量如何定义(设计代码可以用markdown代码符号渲染)?
int a,*p=&a;
1.2 指针加法运算运用在哪种情况,2个指针变量能否相加?
- 用于指针指向数组,指针自增表示数组的下一个
- 指针变量不能相加,没有意义
1.3 指针不赋初值,直接使用,会出现什么情况,请用DEVC验证,并截图展示?
1.4 课堂派上关于分离浮点数的整数部分和小数部分那题,请用DEVC验证实现,并在此贴图展示,同时说明哪句是指针变量做函数形参,函数实参应该怎么表示。指针变量做函数形参有什么用处?
- 指针变量做函数形参 void spllitfloat(float x,int* intpart,float* fracpart)
- 函数实参spllitfloat(x,&realnumber,&decimalfraction);
- 可以在调用函数中改变主函数的值
1.5 请把课本的冒泡排序的函数改成指针变量做形参格式,并把代码写在底下,注意用markdown语法渲染。
#include<stdio.h>
void bubble(int *p,int n);
int main()
{
int a[100],n,i;
scanf("%d\n",&n);
for(i=0;i<n;i++)
scanf("%d",&a[i]);
bubble(a,n);
for(i=0;i<n;i++){
printf("%d ",a[i]);
}
return 0;
}
void bubble(int *p,int n)
{
int i,j,t;
for(i=1;i<n;i++){
for(j=0;j<n-i;j++){
if(*(p+j)>*(p+j+1)){
t=*(p+j);
*(p+j)=*(p+j+1);
*(p+j+1)=t;
}
}
}
}
1.6 如何定义一个指针变量指向数组,如何用指针变量表示数组元素?
int a[10],*p;
p=a;
*(p+1) 等价为a[1]
1.7 如何定义字符指针指向字符串?指针指向字符串后,初始位置在哪里?
char *p="point";
- 初始位置是在p的地址
1.8 利用字符指针操作字符串,如设计函数实现字符串连接,请在此贴图展示代码。说明指针表示字符的方法好处是什么?
#include<stdio.h>
int main()
{
char *p1="how are ";
char *p2="you";
printf("%s%s",p1,p2);
return 0;
}
- 可以减少代码量
- 可以减少内存 的占用量
2.本周你不会内容有什么? - 我不太懂 char *p[]的使用
- 我对于数组的0使用的不是很好
2.1 课堂派错题罗列及如何订正。
- 对于这道题,当时没有真正理解指针指向数组的关系,和理解题目的意思,老师指正后,恍然大悟。
- 这道题也没有理解指针与数组的关系,听完老师上完课,才明白数组名本身也是一个地址,只不过不能改变罢了
2.2 其他不会的?打算怎么解决
其他的都懂了。
3.数组上机考试小结
- 这次考试的败笔是在6-2 jmu-c-二维数组转置并按列排序,其中我的算法是没有错的,但是当时在考试一直以为
我的冒泡排序法出错,在纸上模拟了程序的运行过程发现没有错误,后来一直看,过了好久,才看到我在a[i]^=a[i+1]
=a[i]=a[i]这个过程i+1忘记了。
3.1 那题错了,请罗列?
3.2 错题如何订正,为什么错了?
#include <stdio.h>
int main()
{
int a;
scanf("%d",&a);
printf("%X\n",a);
return 0;
}
#include<stdio.h>
int main()
{
int n,i=-1,j=0;
static int a[10000]={0};
char b[1000];
scanf("%d",&n);
do{
a[++i]=n%16;
n=n/16;
}while(n!=0);
for(j=0;j<=i;j++){
switch(a[j]){
case 1:b[j]='1';break;
case 2:b[j]='2';break;
case 3:b[j]='3';break;
case 4:b[j]='4';break;
case 5:b[j]='5';break;
case 6:b[j]='6';break;
case 7:b[j]='7';break;
case 8:b[j]=8;break;
case 9:b[j]='9';break;
case 10:b[j]='A';break;
case 11:b[j]='B';break;
case 12:b[j]='C';break;
case 13:b[j]='D';break;
case 14:b[j]='E';break;
case 15:b[j]='F';break;
}
}
for(i=i;i>=0;i--)
printf("%c",b[i]);
return 0;
}
- 这道题刚开始设计思路的时候是想通过创建一个字符数组来存放16进制的1至F/f,另外一个字符数组用来存放结果,
后来由于时间不够用,就没写完,回到宿舍就突然想起来,可以直接用上面的代码来运行。