C语言第九次博客作业--指针

一、PTA实验作业

题目1:两个4位正整数的后两位互换

1. 本题PTA提交列表

2. 设计思路

定义循环变量i,两个数组a[4],b[4]
for i=0 to 3
   a[i]*p取各个位
   *p/=10
end
for i=0 to 3
   b[i]*q取各个位
   *q/=10
end
分别对*p和*q重新赋值

3.代码截图

4.本题调试过程碰到问题及PTA提交列表情况说明。

本题没有多大问题,就是想再找一种更简单的做法。

题目2: 输出月份英文名

1. 本题PTA提交列表

2. 设计思路

if形参n不再月份范围内
   return NULL
定义指针数组*a[]并赋值十二个月份
   return a[n-1]

3.代码截图

4.本题调试过程碰到问题及PTA提交列表情况说明。

刚开始我用的switch语句来判断月份,后来在舍友提醒下改成了数组来存放英文并直接返回。

  • 部分正确 :月份不在范围内

解决办法:加入if判断若不在范围内,就返回NULL

题目3:过滤字符串只保留串中的字母字符

1. 本题PTA提交列表

2. 设计思路

定义*a存放ptr,循环变量i,计数变量count
while(*ptr)
   if *ptr 是字母
       将*ptr存放到*(a+i)中  i++
   else count++ 记录非字母
   ptr++继续循环
end
*(a+i)赋值结束符
return count非字母个数

3.代码截图

4.本题调试过程碰到问题及PTA提交列表情况说明。

这道题前面一直在对p直接判断,导致提交运行超时,后来利用另一个指针来存放符合题意的字符并返回,就不会运行超时。

二、截图本周题目集的PTA最后排名。

三、阅读代码

strcpy字符串复制函数原型

char * strcpy(char * dest, const char * src)   // 实现src到dest的复制
{
  if ((src == NULL) || (dest == NULL))    //判断参数src和dest的有效性
  {
          return NULL;
  }
  char *strdest = dest;           //保存目标字符串的首地址
  while ((*strDest++ = *strSrc++)!='\0');    //把src字符串的内容复制到dest下
  return strdest;
}

memcpy内存拷贝函数原型

void *memcpy(void *memTo, const void *memFrom, size_t size)
{
  if((memTo == NULL) || (memFrom == NULL)) //memTo和memFrom必须有效
         return NULL;
  char *tempFrom = (char *)memFrom;             //保存memFrom首地址
  char *tempTo = (char *)memTo;                  //保存memTo首地址      
  while(size -- > 0)                //循环size次,复制memFrom的值到memTo中
         *tempTo++ = *tempFrom++ ;  
  return memTo;
}

strcpy和memcpy主要有以下3方面的区别。

1、复制的内容不同。strcpy只能复制字符串,而memcpy可以复制任意内容,例如字符数组、整型、结构体、类等。
2、复制的方法不同。strcpy不需要指定长度,它遇到被复制字符的串结束符"\0"才结束,所以容易溢出。memcpy则是根据其第3个参数决定复制的长度。

strcpy字符串复制函数原型

#include "assert.h"  
char *strcpy(char *strDest, const char *strSrc)    //使用const来约束strSrc,提高程序的健壮性。如果函数体内的语句试图改动strSrc的内容,编译器将指出错误。
{  
   assert((strDest != NULL) && (strSrc!= NULL));    //对传入参数strDest和strSrc进行检查,禁止空指针传入
    if (strDest == strSrc)  
        return strDest;  
    char *tempDest = strDest;  
    while((*strDest++ = *strSrc++) != '\0');  
    return tempDest;  
}

四、本周学习总结

1.自己总结本周学习内容。

1.1"&"与"*"互为逆运算

  • "&"是取地址符
&(变量名)=>获取变量的地址
  • "*"是指针声明符和间接访问运算符(取值运算符)
*(变量名)=>将变量当作地址,到相应的地址取值

1.2指针

  • 定义指针变量
int *p,i;
p=&i;
p=0;
p=NULL;
p=(int *) 1732;(表示p指向地址为1732的int型变量)
  • 指针变量就是用来储存地址的变量

  • 指针的作用:用来传递地址,作为引用类型的变量,减少内存消耗。

1.3指针与数组

数组名就是一个地址,指向这个数据的开端

*p==a[0]
*(p+n)==a[n]
*p+=1,(*p)++,++*p将指针p所指向的变量值加1
*p++,*(p++)先取*p的值作为表达式的值,在将指针p的值加1

1.4排序和查找

  • 冒泡排序
void bubble (int a[],int n)
{
	int i,j,t;
	for( i=0; i<n; i++)
		for( j=0; j<n-1; j++)
			if(a[j]>a[j+1]){
				t=a[j];a[j]=a[j+1];a[j+1]=t;
			}
}
  • 选择排序
void choose (int a[],int n)
{
	int i,j,t;
	for( i=1; i<n; i++)
		for( j=i+1; j<n; j++)
			if(a[j]>a[i]){
				t=a[j];a[j]=a[i];a[i]=t;
			}
}
  • 二分查找法
int Bsearch(int *p, int n, int x)   \\ 二分查找函数 
{   int low, high, mid;
    low = 0; high = n - 1;       \\开始时查找区间为整个数组 
    while (low <= high)  {         \\循环条件
        mid = (low + high) / 2;    \\ 中间位置
        if (x == p[mid])
            break;                  \\查找成功,中止循环
        else if (x < p[mid])       high = mid - 1;        \\前半段,high前移 
        else       low = mid + 1;       \\后半段,low后移 
    }    
    if(low <= high)   
        return mid;               \\ 找到返回下标 
    else 
        return -1;               \\找不到返回-1 
}

1.5结构体的定义

struct time{
	int hour;
	int minute;
	int second;
};
struct time t;
struct time{
	int hour;
	int minute;
	int second;
} t;

1.6结构体嵌套

struct date{
	int year;
	int month;
	int day;
};
struct person{
	char name[256];
	struct date birthday;
};

1.7结构体的引用和初始化

struct student{
	int number;
	char name[256];
	char sex[6];
	int age;
	int grade;
};
int main()
{
	struct student alan={01,"alan","man",16};
	printf(alan.name);
}

1.8结构体数组

struct student{
	int number;
	char name[256];
	char sex[6];
	int age;
	int grade;
};
int main()
{
	struct student class[5];
	strcpy(alan.name,"alan");
	printf(alan.name);
}

2.罗列本周一些错题。

写函数fun , a数组中n个整数从小到大排列,函数功能是:从a中删除第一个遭到与x值相同的数组元素,删除后a的数组仍然由小到大有序排列。


这道题尤其要注意最后一个空n=n-1,平时很容易忽略掉

posted @ 2017-12-16 15:38  limb171004  阅读(720)  评论(1编辑  收藏  举报