1. 写出String的具体实现

类的定义:

#include <iostream>
#include <cstring>
using namespace std; class String
{
friend ostream & operator<<(ostream &, const String &);
public:
String(const char *str = NULL);
String(const String &);
String & operator=(const String &);
~String();
private:
char *m_data;
};

类成员函数的实现:

String::~String()
{
if (m_data) delete[] m_data;
} String::String(const char *str)
{
if (str == NULL)
{
m_data = new char[1];
m_data[0] = '\0';
}
else
{
m_data = new char[strlen(str)+1];
strcpy(m_data, str);
}
} String::String(const String &other)
{
m_data = new char[strlen(other.m_data)+1];
strcpy(m_data, other.m_data);//String str;str.m_data;
} String & String::operator=(const String &other)
{
if (this == &other) return *this; delete[] m_data;
m_data = new char[strlen(other.m_data)+1];
strcpy(m_data, other.m_data);
return *this;
} ostream & operator<<(ostream &out, const String &s)
{
out << s.m_data;
return out;
} int main()
{
String str;
String str2("hello");
String str3(str2);
String str4 = str2; cout << str << "#" << endl;
cout << str2 << endl;
cout << str3 << endl;
cout << str4 << endl;
}

2. 编写一个标准strcpy函数

总分值为10,下面给出几个不同得分的答案

以下是2分程序片段:

void strcpy(char *dest, char *src)
{
while ((*dest++ = *src++) != '\0');
}

以下是4分程序片段:

//将源字符串加const
void strcpy(char *dest, const char *src)
{
while ((*dest++ = *src++) != '\0');
}

以下是7分程序片段:

//对源地址和目的地址加非NULL断言
void strcpy(char *dest, const char *src)
{
assert((dest != NULL) && (src != NULL));
while ((*dest++ = *src++) != '\0');
}

以下是10分程序片段:

//为了实现链式操作,将目的地址返回
char *strcpy(char *dest, const char *src)
{
assert((dest != NULL) && (src != NULL));
if (dest == src) return dest;
char *addr = dest;
while ((*dest++ = *src++) != '\0');
return addr;
}

可以清楚的看到,小小的strcpy竟然暗藏着这么多玄机,真不是盖的!需要多么扎实的基本功才能写一个完美的strcpy啊!

读者看了不同分值的strcpy版本,应该也可以写出一个10分的strlen函数了:

int strlen(const char *str)
{
assert(str != NULL);
int len = 0;
while (*str++ != '\0') len++;
return len;
}

函数strcmp的实现:

int strcmp(const char *str1, const char *str2)
{
assert((str1 != NULL) && (str2 != NULL));
while (*str1 && *str2 && (*str1 == *str2))
{
str1++;
str2++;
}
return *str1 - *str2;
}

3. 文件中有一组整数,要求从小到大排序后输出到另一个文件中

#include <iostream>
#include <fstream>
#include <vector>
using namespace std;
//simple bubble sort
void sort(vector<int> &data)
{
int temp, n = data.size();
for (int i = 1; i < n; i++)
for (int j = 0; j < n-i; j++)
if (data[j] > data[j+1])
{
temp = data[j];
data[j] = data[j+1];
data[j+1] = temp;
}
} int main()
{
ifstream in(".\\data.txt");
if (!in)
{
cout << "open file error!" << endl;
exit(1);
} int temp;
vector<int> data;
while (!in.eof())
{
in >> temp;
data.push_back(temp);
}
in.close(); sort(data); ofstream out(".\\result.txt");
if (!out)
{
cout << "create file error!" << endl;
exit(1);
}
for (size_t i = 0; i < data.size(); i++)
out << data[i] << " ";
out.close();
}

4. 两个int型数据,不用任何的判断语句如 if、switch、?: 等,找出其中的大值

int max(int x, int y)
{
int buf[2] = {x, y};
unsigned int z = x - y;
z >>= 31;
return buf[z];
}

利用位运算,不过一个很大的正数和一个很小的负数比较可能会溢出。

C/C++一些库函数的实现的更多相关文章

  1. Entity Framework 6 Recipes 2nd Edition(11-11)译 -> 在LINQ中调用数据库函数

    11-11. 在LINQ中调用数据库函数 问题 相要在一个LINQ 查询中调用数据库函数. 解决方案 假设有一个任命(Appointment )实体模型,如Figure 11-11.所示, 我们想要查 ...

  2. Linux系统调用和库函数调用的区别

    Linux下对文件操作有两种方式:系统调用(system call)和库函数调用(Library functions).系统调用实际上就是指最底层的一个调用,在linux程序设计里面就是底层调用的意思 ...

  3. C标准I/O库函数与Unbuffered I/O函数

    一.C标准I/O库函数.Unbuffered I/O函数 1. C标准I/O库函数是如何用系统调用的 fopen(3) 调用open(2)打开制定的文件,返回一个文件描述符(一个int类型的编号),分 ...

  4. [Django]模型提高部分--聚合(group by)和条件表达式+数据库函数

    前言:本文以学习记录的形式发表出来,前段时间苦于照模型聚合中group by 找了很久,官方文章中没有很明确的说出group by,但在文档中有提到!!! 正文(最后编辑于2016-11-12): 聚 ...

  5. STM32库函数编程、Keli/MDK、stm32f103zet6

    catalogue . Cortex-M3地址空间 . 基于标准外设库的软件开发 . 基于固件库实现串口输出(发送)程序 . 红外接收实验 . 深入分析流水灯例程 . GPIO再举例之按键实验 . 串 ...

  6. LPC1768/1769之CAN控制器概述(附库函数下载地址)

    一.背景: 使用LPC1769来做CAN的收发,在此对使用LPC1769的CAN控制器进行收发做个总结和记录,以备下 次开发快速上手使用. 附:LPC1768/1769除了支持最高频率不同以外,其它基 ...

  7. 如何快速上手使用STM32库函数

    一.背景 如前文所述,利用标准库函数的好处在于,可以快速开发,不用去对着数据手册,小心翼翼的一位一位的配置那些繁复的寄存器,因为这些工作意法半导体已经找了一些顶级的工程师帮你做了,杰作既是其库函数.当 ...

  8. 【XLL 框架库函数】 TempActiveRef/TempActiveRef12

    [XLL 框架库函数] TempActiveRef/TempActiveRef12 创建一个包含所有激活工作表引用区域 XLOPER/XLOPER12 LPXLOPER TempActiveRef(B ...

  9. linux内核分析作业4:使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用

    系统调用:库函数封装了系统调用,通过库函数和系统调用打交道 用户态:低级别执行状态,代码的掌控范围会受到限制. 内核态:高执行级别,代码可移植性特权指令,访问任意物理地址 为什么划分级别:如果全部特权 ...

  10. C语言-两个库函数

    两个库函数 --1-- printf函数 1.1 printf 函数的介绍 1.2 格式控制字符串 1.3 %f输出精度的问题 1.4 printf 函数使用注意事项 --2-- scanf函数 2. ...

随机推荐

  1. 【东软实训】SQLselect及其相关操作

    SQL select 及相关操作 SQL是用于访问和处理数据库的标准的计算机语言,我们所使用的的是Oracle SQL 一个数据库通常包含一个或多个表,每个表有一个名字表示,下图即为一个名为“emp” ...

  2. JavaSE-18 常用工具类

    学习要点 Object类 枚举 包装类 Math类 Random类 字符串处理 日期时间 Object类 1  什么是Object类 Object类存储在java.lang包中,是所有java类(Ob ...

  3. 运维笔记:zabbix的运用(1)安装过程

    前言 如果是用了阿里云或者腾讯云,他们都有各种监控帮我们做好.但是如果是遇到了自己维护自己机房的服务器,那么一些可视化或者监控就很有意义了.监控可能有很多种方案,这里就以比较老牌通吃的zabbix来解 ...

  4. A - 栈

    Description   You are given a string consisting of parentheses () and []. A string of this type is s ...

  5. DFS求连通块(漫水填充法)

    G - DFS(floodfill),推荐 Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I6 ...

  6. uva 1592 Database (STL)

    题意: 给出n行m列共n*m个字符串,问有没有在不同行r1,r2,有不同列c1,c2相同.即(r1,c1) = (r2,c1);(r1,c2) = (r2,c2); 如 2 3 123,456,789 ...

  7. 【Codeforces 1031C】Cram Time

    [链接] 我是链接,点我呀:) [题意] 题意 [题解] 如果找到最大的n使得1+2+...+n<=a+b 然后第一天输出1,2.3,4....t1 这里1+2+..+t1<=a 这还远远 ...

  8. 九度oj 题目1074:对称平方数

    题目1074:对称平方数 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:6422 解决:2912 题目描述: 打印所有不超过n(n<256)的,其平方具有对称性质的数. 如11*11 ...

  9. cmake打印变量值

    看下面的例子,我们在cmake定义了一个变量“USER_KEY”,并打印此变量值.status表示这是一般的打印信息,我们还可以设置为“ERROR”,表示这是一种错误打印信息. SET(USER_KE ...

  10. UVA 10652 凸包问题

    #include <cstdio> #include <cstring> #include <algorithm> #include <cmath> # ...