c语言头文件instr,C/C++常用函数合集「建议收藏」

目录C标准库头文件1.memset()2.memcpy()3.strcpy()4.strncpy()5.strcat()6.getline()7.strlen()头文件1.tolower()/toupper()2.isalpha(),isdigit(),isprint()头文件1.pow()2.floor()3.ceil()4.atan()STL头文件1.min(),max()函数2.lower_…

大家好,又见面了,我是你们的朋友全栈君。

目录

C标准库

头文件

1.memset()

2.memcpy()

3.strcpy()

4.strncpy()

5.strcat()

6.getline()

7.strlen()

头文件

1.tolower()/toupper()

2.isalpha(),isdigit(),isprint()

头文件

1.pow()

2.floor()

3.ceil()

4.atan()

STL

头文件

1.min(),max()函数

2.lower_bound()

3.upper_bound()

4.next_permutation()/prev_permutation()

6.Sort()

7.fill()

8.reverse()

C标准库

头文件

1.memset()

函数原型:memset(void *s , int c , size_t n)

作用:将已开辟内存空间s的首n个字节的值设置为c。一般用于在对字符串进行初始化为‘\0’或‘ ’

注意:1.s为首地址,c为要赋予的字符,n为长度

2.一般不用于初始化数字数组

代码示例:

#include

#include

int main(){

char str[5]={‘1′,’2′,’3′,’4′,’5’};

printf(“原始字符数组:”);

for(int i=0;i<5;i++)

printf(“%c “,str[i]);

printf(“\n”);

//    内存初始化

memset(str,’\0′,5);

printf(“初始化后的字符数组:”);

for(int i=0;i<5;i++)

printf(“%c “,str[i]);

return 0;

}

2.memcpy()

函数原型:void *memcpy(void *dest, const void *src, size_t n);

作用:将以src开头,长度为n的内存空间里的内容拷贝到以dest开头的内存空间里去。

例:

char a[100],b[50];

memcpy(b,a,sizeof(b)); //将a的sizeof(b)个元素赋给b

注意:如果用sizeof(a),会造成b的内存地址溢出。

3.strcpy()

函数原型:char *strcpy(char* dest, const char *src);

作用:把从src地址开始且含有NULL结束符的字符串复制到以dest开始的地址空间

例:

char a[100],b[50];

strcpy(a,b);

注意:遇到‘\0’时就结束拷贝。

4.strncpy()

函数原型:strncpy(char* dest,const char* src,int n)

作用:把src所指的字符串中以src地址开始的前n个字节复制到dest所指的空间中,并返回dest。

注意:1.结果dest不包括结束符NULL(‘\0’)

2.如果src的长度小于n个字节,则以NULL填充dest直到复制完n个字节

代码示例

#include

#include

using namespace std;

int main(){

char s[] = {“hello”};

char s2[10];

cout<

return 0;

}

5.strcat()

函数原型:char *strcat(char *dest, const char *src);

作用:将两个char类型数组相连,结果放在dest中,返回拼接后指向dest的指针。

代码示例

#include

#include

using namespace std;

int main(){

char s[] = {“hello”};

char s2[10];

//    将s2数组赋空字符

memset(s2,’\0′,10);

//    连接字符数组s和s2

strcat(s2,s);

for(int i=0;i<10;i++){

cout<

}

return 0;

}

6.getline()

函数原型:istream& getline ( istream &is , string &str , char delim );

参数解释

is进行读入操作的输入流,常用cinstr已声明的用于存储读入内容的对象,常为string类型delim终结符

作用:将输入流is中读到的字符存入str中,直到遇到终结符delim才结束。如果没有定义delim,则默认为 ‘\n'(换行符)。

注意:getline遇到delim时停止读入(但读入了delim),然后将所读内容存储到string对象中(不存delim)下次读入操作时,将在delim的下个字符开始读入。

代码示例:

#include

#include

int main(){

string str;

getline(cin,str,’o’);

printf(“%s”,str.c_str());  // string类型字符串不能直接使用printf输出,需要调用string中的c_str()函数

}

7.strlen()

函数原型:size_t strlen(const char *string);

作用:计算string字符串或者以char *声明的字符数组的长度。

头文件

1.tolower()/toupper()

作用:改变字母大小写

例:

char n=’h’;

cout<

注意:n的值并没有改变,仍然为‘h’。

2.isalpha(),isdigit(),isprint()

作用:用来对是否是字母,数字,可打印字符(非控制字符)进行判断

头文件

1.pow()

函数原型:double pow(double x, double y)

作用:返回x的y次方

2.floor()

函数原型:double floor(double x);

作用:用于输出浮点类型中小于此数的最大整数

注:floor(n+0.5)可用于进行四舍五入的处理

3.ceil()

函数原型:double ceil(double x);

作用:用于输出浮点类型中大于此数的最小整数

4.atan()

作用:用来求π的值:atan(1)=π/4    π=4.0*atan(1)

代码示例:

#include

#include

using namespace std;

// 求π的值,保留小数点后15为小数

int main(){

double pi = 4*atan(1);

printf(“%.15f”,pi);     //保留π后的十五位小数

}

运行结果:

STL

头文件

1.min(),max()函数

作用:返回两个元素中最小(最大)的一个

2.lower_bound()

函数原型:lower_bound(int* first,int* last,int val);

作用:查找有序区间[first,last]中第一个大于等于val的位置

代码示例:

#include

#include

using namespace std;

int main(){

int n[10];

for(int i=0;i<10;i++)

n[i]=i;

cout<

cout<

return 0;

}

运行结果:

3.upper_bound()

作用:大致和lower_bound()相同,不过查找的是有序区间[first,last]中第一个大于x的位置

4.next_permutation()/prev_permutation()

格式:next_permutation(数组名,数组名+数组长度)

作用:将数组的排序改为当前数组全排列的下/上一个

返回值:若当前数组存在下/上一个全排列,则返回ture,否则返回false。

解释:假设数组为a,b,c。则该数组的全排列为abc,acb,bac,bca,cab,cba。若当前数组为bac,则其全排列的上一个数组即为acb,下一个数组为bca

注意:若要求数组所有的全排列,需要将数组进行升序排列,否则只能找出该序列之后的全排列数。

代码示例:

#include

#include

using namespace std;

//输出abc的全排列

int main(){

char ans[3]={‘a’,’b’,’c’};

do{

for(int i=0;i<3;++i)

cout<

cout<

}while(next_permutation(ans,ans+3));

return 0;

}

运行结果:

6.Sort()

函数原型:void sort(RanIt first, RanIt last, Pred pr);

参数解释

first指向容器首地址的指针(数组名)last指向容器尾地址的指针(数组名+数组长度)pr比较方法(默认为升序)

具体用法:

sort(begain,end,less())   升序

sort(begain,end,greater()) 降序

注意:开始和结尾用的都是指针

示例代码:

#include

#include

using namespace std;

int main(){

char ch[5]={‘e’,’a’,’c’,’b’,’d’};

cout<

//     升序排列

sort(ch,ch+5);

cout<

//     降序排列

sort(ch,ch+5,greater());

cout<

return 0;

}

运行结果:

7.fill()

函数原型:void fill(first,last,val);

参数解释

first起始地址last末尾地址val将要替换的值

作用:可将数组的值初始化成指定值

例如:

1.初始化一维数组

int a[10];

fill(a,a+10,80);

2.初始化二维数组

int a[10][10];

fill(a[0],a[0]+10*10,90);

8.reverse()

函数原型:void reverse (BidirectionalIterator first, BidirectionalIterator last)

作用:将[first,last)范围内的字符顺序反转

代码示例:

#include

#include

#include

using namespace std;

int main ()

{

char s1[10]=”hello”;

string s2=”world”;

cout<

cout<

//    reverse的使用

reverse(s1,s1+strlen(s1));

reverse(s2.begin(),s2.end());

cout<

cout<

}

运行结果:

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/126713.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • Longest Common Prefix_LeetCode

    Longest Common Prefix_LeetCode1.思路:求strs数组的长度,当len==0,len==1分开考虑;i从1-min_len,以strs[0][i]作为对照,一旦出现strs[j][i]!=strs[0][i],结束循环,则输出之前判断好了的字符串。 classSolution:deflongestCommonPrefix(self,strs):""":typestrs…

  • 修改ntp服务器地址,修改ntp服务器地址

    修改ntp服务器地址,修改ntp服务器地址修改ntp服务器地址内容精选换一换修改子网名称、DNS服务器地址等。当前在部分区域中,子网已从虚拟私有云中解耦,解耦后子网拥有独立入口。未解耦:在虚拟私有云详情页的“子网”页签,可对子网进行操作。本小节的操作步骤指导以此入口为例。已解耦:在进入“网络>虚拟私有云”后,在左侧导航栏直接选择“子网”,可对子网进行操作。登录管理控制台。在管理控制台左上角单击,选择区域和项目网关创建成功以后,…

  • Python如何运行程序

    Python如何运行程序Python解释器简介解释器是一种让其他程序运行起来的程序。Python也有一个名为解释器的软件包,当你编写了一段Python程序,Python解释器将读取程序,并按照其中的命令执行,得出结果。实际

  • [时空权衡]字符串匹配KMP算法代码(引自算法导论)

    [时空权衡]字符串匹配KMP算法代码(引自算法导论)

  • 软考中的设计模式[通俗易懂]

    软考中的设计模式[通俗易懂]软考中的设计模式

  • hotumoyi吉他_木棒能做什么

    hotumoyi吉他_木棒能做什么乔治拿来一组等长的木棒,将它们随机地砍断,使得每一节木棍的长度都不超过 50 个长度单位。然后他又想把这些木棍恢复到为裁截前的状态,但忘记了初始时有多少木棒以及木棒的初始长度。请你设计一个程序,帮助乔治计算木棒的可能最小长度。每一节木棍的长度都用大于零的整数表示。输入格式输入包含多组数据,每组数据包括两行。第一行是一个不超过 64 的整数,表示砍断之后共有多少节木棍。第二行是截断以后,所得到的各节木棍的长度。在最后一组数据之后,是一个零。输出格式为每组数据,分别输出原始木棒的可能最小长度

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号