append函数c语言 append函数r语言

c语言链表问题,两个append函数看上去差不多为什么有一个就不行

第2张图片代码存在两个问题

创新互联建站长期为上千客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为大同企业提供专业的成都网站制作、网站设计、外贸网站建设大同网站改版等技术服务。拥有十余年丰富建站经验和众多成功案例,为您定制开发。

1、强行加了node head头,再插入数据只能从head后面插,这其实是没必要的

2、node head头未经初始化,无法保证其p_next是NULL还是垃圾数据(可能是垃圾数据),那么看下while循环,如果head.p_next里的数据是垃圾的话,导至第一次while判断句的temp-p_next不为NULL但也不是能使用的指针,然后进入while内部将不能使用的指针赋值给temp,再进行while第二次判断,由于temp是无效指针,运行temp-p_next必然崩溃

c语言的void append( void)具体是什么意思?

在C语言中,任何时候你都可以用其它类型的指针来代替void指针(在C++中同样可以),或者用void指针来代替其它类型的指针(在C++中需要进行强制转换),并且不需要进行强制转换。例如,你可以把char *类型的指针传递给需要void指针的函数。

什么时候使用void指针?

当进行纯粹的内存操作时,或者传递一个指向未定类型的指针时,可以使用void指针。void指针也常常用作函数指针。

有些C代码只进行纯粹的内存操作。在较早版本的C中,这一点是通过字符指针(char *)实现的,但是这容易产生混淆,因为人们不容易判断一个字符指针究竟是指向一个字符串,还是指向一个字符数组,或者仅仅是指向内存中的某个地址。

求c++大神给说下string中的append()函数的用法

要想使用标准C++中string类,必须要包含

#include string// 注意是string,不是string.h,带.h的是C语言中的头文件

using std::string;

using std::wstring;

using namespace std;

下面你就可以使用string/wstring了,它们两分别对应着char和wchar_t。

string和wstring的用法是一样的,以下只用string作介绍:

string类的构造函数:

string(const char *s); //用c字符串s初始化

string(int n,char c); //用n个字符c初始化

此外,string类还支持默认构造函数和复制构造函数,如string s1;string s2="hello";都是正确的写法。当构造的string太长而无法表达时会抛出length_error异常 ;

string类的字符操作:

const char operator[](int n)const;

const char at(int n)const;

char operator[](int n);

char at(int n);

operator[]和at()均返回当前字符串中第n个字符的位置,但at函数提供范围检查,当越界时会抛出out_of_range异常,下标运算符[]不提供检查访问。

const char *data()const;//返回一个非null终止的c字符数组

const char *c_str()const;//返回一个以null终止的c字符串

int copy(char *s, int n, int pos = 0) const;//把当前串中以pos开始的n个字符拷贝到以s为起始位置的字符数组中,返回实际拷贝的数目

string的特性描述:

int capacity()const; //返回当前容量(即string中不必增加内存即可存放的元素个数)

int max_size()const; //返回string对象中可存放的最大字符串的长度

int size()const; //返回当前字符串的大小

int length()const; //返回当前字符串的长度

bool empty()const; //当前字符串是否为空

void resize(int len,char c);//把字符串当前大小置为len,并用字符c填充不足的部分

string类的输入输出操作:

string类重载运算符operator用于输入,同样重载运算符operator用于输出操作。

函数getline(istream in,string s);用于从输入流in中读取字符串到s中,以换行符'\n'分开。

string的赋值:

string operator=(const string s);//把字符串s赋给当前字符串

string assign(const char *s);//用c类型字符串s赋值

string assign(const char *s,int n);//用c字符串s开始的n个字符赋值

string assign(const string s);//把字符串s赋给当前字符串

string assign(int n,char c);//用n个字符c赋值给当前字符串

string assign(const string s,int start,int n);//把字符串s中从start开始的n个字符赋给当前字符串

string assign(const_iterator first,const_itertor last);//把first和last迭代器之间的部分赋给字符串

string的连接:

string operator+=(const string s);//把字符串s连接到当前字符串的结尾

string append(const char *s); //把c类型字符串s连接到当前字符串结尾

string append(const char *s,int n);//把c类型字符串s的前n个字符连接到当前字符串结尾

string append(const string s); //同operator+=()

string append(const string s,int pos,int n);//把字符串s中从pos开始的n个字符连接到当前字符串的结尾

string append(int n,char c); //在当前字符串结尾添加n个字符c

string append(const_iterator first,const_iterator last);//把迭代器first和last之间的部分连接到当前字符串的结尾

string的比较:

bool operator==(const string s1,const string s2)const;//比较两个字符串是否相等

运算符"","","=","=","!="均被重载用于字符串的比较;

int compare(const string s) const;//比较当前字符串和s的大小

int compare(int pos, int n,const string s)const;//比较当前字符串从pos开始的n个字符组成的字符串与s的大小

int compare(int pos, int n,const string s,int pos2,int n2)const;//比较当前字符串从pos开始的n个字符组成的字符串与s中

//pos2开始的n2个字符组成的字符串的大小

int compare(const char *s) const;

int compare(int pos, int n,const char *s) const;

int compare(int pos, int n,const char *s, int pos2) const;

compare函数在时返回1,时返回-1,==时返回0

string的子串:

string substr(int pos = 0,int n = npos) const;//返回pos开始的n个字符组成的字符串

string的交换:

void swap(string s2); //交换当前字符串与s2的值

string类的查找函数:

int find(char c, int pos = 0) const;//从pos开始查找字符c在当前字符串的位置

int find(const char *s, int pos = 0) const;//从pos开始查找字符串s在当前串中的位置

int find(const char *s, int pos, int n) const;//从pos开始查找字符串s中前n个字符在当前串中的位置

int find(const string s, int pos = 0) const;//从pos开始查找字符串s在当前串中的位置

//查找成功时返回所在位置,失败返回string::npos的值

int rfind(char c, int pos = npos) const;//从pos开始从后向前查找字符c在当前串中的位置

int rfind(const char *s, int pos = npos) const;

int rfind(const char *s, int pos, int n = npos) const;

int rfind(const string s,int pos = npos) const;

//从pos开始从后向前查找字符串s中前n个字符组成的字符串在当前串中的位置,成功返回所在位置,失败时返回string::npos的值

int find_first_of(char c, int pos = 0) const;//从pos开始查找字符c第一次出现的位置

int find_first_of(const char *s, int pos = 0) const;

int find_first_of(const char *s, int pos, int n) const;

int find_first_of(const string s,int pos = 0) const;

//从pos开始查找当前串中第一个在s的前n个字符组成的数组里的字符的位置。查找失败返回string::npos

int find_first_not_of(char c, int pos = 0) const;

int find_first_not_of(const char *s, int pos = 0) const;

int find_first_not_of(const char *s, int pos,int n) const;

int find_first_not_of(const string s,int pos = 0) const;

//从当前串中查找第一个不在串s中的字符出现的位置,失败返回string::npos

int find_last_of(char c, int pos = npos) const;

int find_last_of(const char *s, int pos = npos) const;

int find_last_of(const char *s, int pos, int n = npos) const;

int find_last_of(const string s,int pos = npos) const;

int find_last_not_of(char c, int pos = npos) const;

int find_last_not_of(const char *s, int pos = npos) const;

int find_last_not_of(const char *s, int pos, int n) const;

int find_last_not_of(const string s,int pos = npos) const;

//find_last_of和find_last_not_of与find_first_of和find_first_not_of相似,只不过是从后向前查找


当前题目:append函数c语言 append函数r语言
文章起源:http://scyanting.com/article/hihsjo.html