c提高第三次作业
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提高第三次作业的更多相关文章
- c提高第五次作业
重写结构体嵌套一级指针老师和二级指针学生的代码 //结构体类型,每个导师有三个学生 typedef struct Teacher { char *tName; //导师 char **stu; //三 ...
- c提高第四次作业
1. 简述指针数组和数组指针的区别?答: 指针数组:是一个数组,每个元素都是指针 数组指针:是一个指针,指向数组的指针 2. 如何定义一个指向 int a[10] 类型的指针变量(数组指针)(使用3种 ...
- OO第一单元三次作业总结
写在前面 第一单元作业是针对输入的多项式进行格式合法判断,然后进行求导,结果长度优化,最后输出.三次难度递增,不断添加新的需求,总体感觉在实现方面没有多大困难(?),个人主要困扰环节是寻找自己未知bu ...
- oo前三次作业博客总结
第一次作业 实现多项式的加减运算,主要问题是解决输入格式的判断问题. 输入实例: {(3,0), (2,2), (12,3)} + {(3,1), (-5,3)} – {(-199,2), (29,3 ...
- 耿丹CS16-2班第三次作业汇总
-- Deadline: 2016-10-12 22:48 -- 作业内容: 1.实验2-6 猜数字游戏 2.实验2-7 判断能否为三角形 3.实验2-8 个人所得税计算器 -- 第三次作业总结: 1 ...
- JAVA第三周作业(从键盘输入若干数求和)
JAVA第三周作业(从键盘输入若干数求和) 在新的一周,我学习了JAVA的IO编程.下面的代码实现了从键盘输入若干数求和的目标.import java.util.Scanner; public cla ...
- 第三次作业:caculator
第三次作业 作业链接 ********* 遇到的问题: Scan类: 队列的使用方法不了解,上网查询并自己练习了一下才初步了解,才运用到作业 . 判断数字用的 if (input[i] >= ' ...
- HTML第三天作业做的表格
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xht ...
- 第三次作业——《K米评测》
第三次作业--<K米评测> 一.调研.评测 上手体验 APP的图标做的不错,一眼就知道和KTV唱歌相关的 点进去就是连接包箱的界面和直播界面,把软件最重要的两个功能展示出来了,一目了然 热 ...
随机推荐
- 如何搭建一个VUE项目
搭建环境 搭建node环境 下载 1.进入node.js官方网站下载页,点击下图中框出位置,进行下载即可,当前版本为8.9.4,下载网址为:https://nodejs.org/zh-cn/downl ...
- Dynamics 365中的常用Associate和Disassociate消息汇总
摘要: 微软动态CRM专家罗勇 ,回复301或者20190123可方便获取本文,同时可以在第一间得到我发布的最新博文信息,follow me!我的网站是 www.luoyong.me . 因为编程时候 ...
- DataSnap 多层返回数据集分析FireDAC JSON
采用服务器返回数据,一种是返回字符串数据例如JSON,跨平台跨语言,任何语言调用都支持兼容,类似WEBService. 第二种是紧密结合c++builder语言,传输DataSet,可以是Client ...
- Elasticsearch 安装操作手册
第一部分 ES安装环境的准备和初始化 现在交心的版本Elasticsearch 5.6.3 官方建议安装Oracle的JDK8,安装前先检查机器是否已安装JDK. Step 1 检查环境机器是否已安装 ...
- c/c++ 拷贝控制 右值与const引用
拷贝控制 右值与const引用 背景:当一个函数的返回值是自定义类型时,调用侧用什么类型接收?? 1,如果自定义类型的拷贝构造函数的参数用const修饰了:可以用下面的方式接收. Test t2 = ...
- 周末班:Python基础之模块
什么是模块 什么是模块? 常见的场景:一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 但其实import加载的模块分为四个通用类别: 1 使用python编写 ...
- 【Python 22】52周存钱挑战2.0(列表list和math函数)
1.案例描述 按照52周存钱法,存钱人必须在一年52周内,每周递存10元.例如,第一周存10元,第二周存20元,第三周存30元,直到第52周存520元. 记录52周后能存多少钱?即10+20+30+. ...
- HBase Rowkey 设计指南
为什么Rowkey这么重要 RowKey 到底是什么 我们常说看一张 HBase 表设计的好不好,就看它的 RowKey 设计的好不好.可见 RowKey 在 HBase 中的地位.那么 RowKey ...
- LCA-RMQ+欧拉序
还是那一道洛谷的板子题来说吧 传送门 其实好几天之前就写了 结果dr实在是太弱了 没有那么多的精力 于是就一直咕咕咕了 哎 今天终于补上来了 LCA概念传送门 RMQ传送门 这个算法是基于RMQ和欧拉 ...
- Exp6 信息搜集与漏洞扫描 20165110
Exp6 信息搜集与漏洞扫描 20165110 一.实践目标 掌握信息搜集的最基础技能与常用工具的使用方法. 二.实践内容 (1)各种搜索技巧的应用 (2)DNS IP注册信息的查询 (3)基本的扫描 ...