1. char buf[] = "abcdef";

//下面有啥区别?
const char *p = buf; //p指向的内存不能变
char const *p = buf; //p指向的内存不能变
char * const p = buf; //p的地址不能变
const char *const *p = buf; //p的地址和指向的内存都不能改变

2. char *p1[] = {"1111", "2222", "3333"};
sizeof(p1)/sizeof(p1[0]) = ?

//结果是3

char *p2[10] = {"1111", "2222", "3333"};
sizeof(p2)/sizeof(p2[0]) = ?

//10

char p3[][30] = {"1111", "2222", "3333"};
sizeof(p3)/sizeof(p3[0]) = ?

//3

char p4[10][30] = {"1111", "2222", "3333"};
sizeof(p4)/sizeof(p4[0]) = ?

//10

3. char buf[][30] = {"1111", "2222", "3333"};
二维数组做函数参数,为什么不能这么写?
void fun(char **buf);

void fun(char **buf) 和 void fun(char buf[][30]) 有什么区别?

步长不一样,buf[][30]指定了+1 时候的步长30

4. 画出三种二级指针内存模型图

mian()
{
//指针数组
char *p1[] = {"123", "456", "789"};

//二维数组
char p2[3][4] = {"123", "456", "789"};

//手工二维内存
char **p3 = (char **)malloc(3 * sizeof(char *)); //char *array[3];

int i = 0;
for (i=0; i<3; i++)
{
p3[i] = (char *)malloc(10*sizeof(char)); //char buf[10]

sprintf(p3[i], "%d%d%d", i, i, i);
}

}

5. 有字符串有以下特征(“abcd11111abcd2222abcdqqqqq”),求写一个函数接口,输出以下结果。
把字符串替换成(dcba11111dcba2222dcbaqqqqq),并把结果传出。
要求:
1. 正确实现接口和功能
2. 编写测试用例
/*
src: 原字符串
dst: 生成的或需要填充的字符串
sub: 需要查找的子字符串
new_sub:提换的新子字符串

return : 0 成功
-1 失败
*/
int replaceSubstr(/* in */char *src, /* out */char** dst,
/* in */char *sub, /* in */char *new_sub);

#pragma warning(disable:4996)
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#pragma disable
/*
有字符串有以下特征(“abcd11111abcd2222abcdqqqqq”), 求写一个函数接口,输出以下结果。
把字符串替换成(dcba11111dcba2222dcbaqqqqq),并把结果传出。
要求:
1. 正确实现接口和功能
2. 编写测试用例 src: 原字符串
dst: 生成的或需要填充的字符串
sub: 需要查找的子字符串
new_sub:提换的新子字符串 return : 0 成功
-1 失败
*/
int replaceSubstr(/* in */char *src, /* out */char** dst,
/* in */char *sub, /* in */char *new_sub) {
if (src == NULL || dst == NULL||
sub == NULL || new_sub == NULL)
{
return -;
}
/*
src="ddddabcd11111abcd2222abcdqqqqq"
sub="abcd"
new_sub="aaaaaa"
*/ char *start = src;
char *p = NULL;
char tmp[] = { };
int len = ; do {
/*
src="ddddabcd11111abcd2222abcdqqqqq"
sub="abcd"
new_sub="aaaaaa"
*/
p = strstr(start, sub);
if (p != NULL) {
len = ;
len = p - start;
if (len > ) {
strncat(tmp, start, len); //tmp="dddd"
}
strncat(tmp, new_sub, strlen(new_sub)); //tmp="ddddaaaaa" //重新设置起点位置
start = p + strlen(sub);
}
else {
strcat(tmp, start);
break;
} } while (*start != '\0');//strrt[i]!=0 char *buf = (char*)malloc(strlen(tmp) + );
strcpy(buf, tmp); //间接赋值,是指针存在的最大意义
*dst = buf; return ;
}
void freeBuf(char *buf) {
if (buf != NULL) {
free(buf);
buf = NULL;
}
}
void freeBuf1(char **buf) {
char *tmp = *buf; //tmp是指向堆区的指针
if (tmp != NULL) {
free(tmp);
}
*buf = NULL;
}
int main() {
char *p = "dddabcd11111abcd2222abcdqqqqq";
char *buf = NULL;//在哪replaceSubstr函数中分配空间
int ret = ; ret = replaceSubstr(p, &buf, "abcd", "aaaaa");
if (ret != ) {
printf("replaceSubstr err:%d\n", ret);
system("pause");
return ret;
}
printf("p=%s\n", p);
printf("buf=%s\n", buf);
/*
if (buf != NULL) {
free(buf);
buf = NULL;
}
*/ freeBuf(buf);
//freeBuf1(&buf);
printf("\n");
system("pause");
return ;
}

6. 有一个字符串符合以下特征(“abcdef,acccd,eeee,aaaa,e3eeee,ssss,”)

写两个函数(API),输出以下结果
第一个API(第二种内存模型)
1)以逗号分隔字符串,形成二维数组,并把结果传出
2)把二维数组行数运算结果也传出
int spitString(const char *str, char c, char buf[10][30], int *count);

第二个API(第三种内存模型)
1)以逗号分隔字符串,形成一个二级指针。
2)把一共拆分多少行字符串个数传出
int spitString2(const char *str, char c, char **myp /*in*/, int *count);

要求:
1, 能正确表达功能的要求,定义出接口。
2, 正确实现接口和功能.
3, 编写正确的测试用例.

#pragma warning(disable:4996)
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
//有一个字符串符合以下特征(“abcdef,acccd,eeee,aaaa,e3eeee,ssss,”) int spitString(const char *str, char c, char buf[][], int *count) {
if (str == NULL || count == NULL) {
return -;
}
//str="abcdef,acccd,eeee,aaaa,e3eeee,ssss,"
const char *start = str;
char *p = NULL;
int i = ;
do {
p = strchr(start, c);//strchr在c++中的返回值为const char*
if (p != NULL) {
int len = p - start;
strncpy(buf[i], start, len);
//结束符
buf[i][len] = ; i++; //重新设定起点位置
start = p + ;
}
else {
//printf("strat=%s\n", start);
strcpy(buf[i], start);
i++;
break;
}
} while (*start != ); if (i == ) {
return -;
} *count = i; return ;
}
char **getMem(int n) {
char **buf = NULL;//char *buf[n]
buf = (char**)malloc(n * sizeof(char*));//char*
if (buf == NULL) {
return NULL;
} int i = ;
for (i = ; i < n; i++) {
buf[i] = (char*)malloc();
}
return buf;
} int spitString2(const char *str, char c, char **buf /*in*/, int *count) {
if (str == NULL || count == NULL) {
return -;
}
//str="abcdef,acccd,eeee,aaaa,e3eeee,ssss,"
const char *start = str;
char *p = NULL;
int i = ;
do {
p = strchr(start, c);//strchr在c++中的返回值为const char*
if (p != NULL) {
int len = p - start;
strncpy(buf[i], start, len);
//结束符
buf[i][len] = ; i++; //重新设定起点位置
start = p + ;
}
else {
//printf("strat=%s\n", start);
strcpy(buf[i], start);
i++;
break;
}
} while (*start != ); if (i == ) {
return -;
} *count = i; return ;
return ;
}
int main(){
const char *p = "abcdef,acccd,eeee,aaaa,e3eeee,ssss,";
char **buf = NULL; int n = ;
int i = ;
int ret = ; buf = getMem();
if (buf == NULL) { return -;
} ret = spitString2(p, ',', buf, &n);
if (ret != ) {
printf("spitString err:%d", ret); system("pause");
return ret;
} for (i = ; i < n; i++) {
printf("%s\n", buf[i]);
} for (i = ; i < n; i++) {
free(buf[i]);
buf[i] = NULL;
}
if (buf != NULL) {
free(buf);
buf = NULL;
}
printf("\n");
system("pause");
return ;
}
/*
测试函数1
const char *p = "abcdef,acccd,eeee,aaaa,e3eeee,ssss,";
char buf[10][30] = { 0 }; int n = 0;
int i = 0;
int ret = 0;
ret = spitString(p, ',', buf, &n);
if (ret != 0) {
printf("spitString err:%d", ret); system("pause");
return ret;
} for (i = 0; i < n; i++) {
printf("%s\n", buf[i]);
}
*/

c提高第三次作业的更多相关文章

  1. c提高第五次作业

    重写结构体嵌套一级指针老师和二级指针学生的代码 //结构体类型,每个导师有三个学生 typedef struct Teacher { char *tName; //导师 char **stu; //三 ...

  2. c提高第四次作业

    1. 简述指针数组和数组指针的区别?答: 指针数组:是一个数组,每个元素都是指针 数组指针:是一个指针,指向数组的指针 2. 如何定义一个指向 int a[10] 类型的指针变量(数组指针)(使用3种 ...

  3. OO第一单元三次作业总结

    写在前面 第一单元作业是针对输入的多项式进行格式合法判断,然后进行求导,结果长度优化,最后输出.三次难度递增,不断添加新的需求,总体感觉在实现方面没有多大困难(?),个人主要困扰环节是寻找自己未知bu ...

  4. oo前三次作业博客总结

    第一次作业 实现多项式的加减运算,主要问题是解决输入格式的判断问题. 输入实例: {(3,0), (2,2), (12,3)} + {(3,1), (-5,3)} – {(-199,2), (29,3 ...

  5. 耿丹CS16-2班第三次作业汇总

    -- Deadline: 2016-10-12 22:48 -- 作业内容: 1.实验2-6 猜数字游戏 2.实验2-7 判断能否为三角形 3.实验2-8 个人所得税计算器 -- 第三次作业总结: 1 ...

  6. JAVA第三周作业(从键盘输入若干数求和)

    JAVA第三周作业(从键盘输入若干数求和) 在新的一周,我学习了JAVA的IO编程.下面的代码实现了从键盘输入若干数求和的目标.import java.util.Scanner; public cla ...

  7. 第三次作业:caculator

    第三次作业 作业链接 ********* 遇到的问题: Scan类: 队列的使用方法不了解,上网查询并自己练习了一下才初步了解,才运用到作业 . 判断数字用的 if (input[i] >= ' ...

  8. HTML第三天作业做的表格

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xht ...

  9. 第三次作业——《K米评测》

    第三次作业--<K米评测> 一.调研.评测 上手体验 APP的图标做的不错,一眼就知道和KTV唱歌相关的 点进去就是连接包箱的界面和直播界面,把软件最重要的两个功能展示出来了,一目了然 热 ...

随机推荐

  1. Eureka相关知识点

    本文讲述的是 Eureka server, 服务提供者.消费者的一些概念和配置说明. Eureka Server 服务注册中心 Eureka的高可用设计 Eureka侧重点是AP,高可用;Eureka ...

  2. C#设计模式之二十一访问者模式(Visitor Pattern)【行为型】

    一.引言 今天我们开始讲“行为型”设计模式的第九个模式,该模式是[访问者模式],英文名称是:Visitor Pattern.如果按老规矩,先从名称上来看看这个模式,我根本不能获得任何对理解该模式有用的 ...

  3. Python re 模块

    Python re 模块 TOC 介绍 作用 正则表达式语法 贪婪和非贪婪 普通字符和特殊字符 分组(比较重要) re modul level 方法 正则表达式对象 匹配对象 常用例子 注意事项 Ja ...

  4. vue 获取页面详情后 切换页面时 如何监听用户是否修改过信息

    可以用 beforeRouteLeave 和 updated 来判断.export default { name: 'supplier', components:{cmtWrap,cmtContent ...

  5. Dynamics 365 Customer Engagement安装FAQ

    微软动态CRM专家罗勇 ,回复310或者20190308可方便获取本文,同时可以在第一间得到我发布的最新博文信息,follow me!我的网站是 www.luoyong.me . 本文参考了包括但不限 ...

  6. nginx sub模块替换文本

    nginx的ngx_http_sub_module模块,可以用于修改网站响应内容中的字符串,如过滤敏感词.第三方模块ngx_http_substitutions_filter_module,弥补了ng ...

  7. 性能测试 基于Python结合InfluxDB及Grafana图表实时采集Linux多主机性能数据

    基于Python结合InfluxDB及Grafana图表实时采集Linux多主机性能数据   by:授客 QQ:1033553122 实现功能 测试环境 环境搭建 使用前提 使用方法 运行程序 效果展 ...

  8. Android 反射获取一个方法(方法的参数不一样)

    private Method forget; private Method connect_netID; private Method connect_wifiConfig; private Meth ...

  9. C++ 虹软人脸识别 ArcFace 2.0 Demo

    环境配置: 开发环境:Win10 + VS 2013 SDK版本:ArcFace v2.0 OpenCV版本:2.4.9 平台配置: x64.x86下Release.Debug SDK 下载地址:戳这 ...

  10. C++客户端访问WebService VS2008

    VS2008及之后的版本已经不支持使用C++开发WEBService服务了,如果要在VS上开发WEBService,需要使用C#开发语言. 一.gSOAP简介 gSOAP编译工具提供了一个基于SOAP ...