README
这里面的其实是我记在印象笔记里面积累的东西,因为我直接在vscode里面进行输入更新查找的操作,所以感觉非常方便。可是用久了就会厌烦频繁更新开发者令牌的步骤~啊,所以我计划把我经常进行改动的笔记,也就是写满干货的笔记转移到简书上了。
reverse
下面代码实现将char 类型的字符串颠倒,一维数组
void reverse(char s[])
{
int len = strlen(s);
for(int i = 0 ; i < len / 2 ; i++ )
{
int temp = s[i];
s[i] = s[len -1 -i ];
s[len -1- i] = temp;
}
}
二维的,未验证
void reverse(char s[][256], int n)
{
for (int i = 0; i < n; i++)
{
int len = strlen(s[i]);
for (int j = 0; j < len / 2; j++)
{
int temp = s[i][j];
s[i][j] = s[i][len - 1 - j];
s[i][len - 1 - j] = temp;
}
}
}
fgets
下面代码实现gets功能
fgets(s, sizeof(s), stdin);
if(s[strlen(s) - 1] == '\n') s[strlen(s) - 1] = '\0'; // 去掉换行符
下文有详细介绍
getline
一个超级好用的替代gets的方法,舍弃掉了char,采用string来处理
#include<iostream>
#include<string>
using namespace std;
int main(){
for (int i=0;i < 3 ;i++){
string city,provice,state;
getline(cin,city,',');//getline可以输入整行的字符串,第三个参数表示已','为结束,默认分隔符以行结束。
getline(cin,provice,',');
getline(cin,state);
cout<<"City:"<< city <<" Provice: "<<provice<<" State:"<<state <<endl;
}
return 0;
}
reverse()
#include<algorithm>
reverse(s.begin(), s.end());
上面是原地反转的方法,如果需要反转到别的 string 里面,一样简单:
s1.assign(s.rbegin(), s.rend());
效率也相当理想。
strcmp
C/C++函数,比较两个字符串
设这两个字符串为str1,str2,
若str1=str2,则返回零;
若str1<str2,则返回负数;
若str1>str2,则返回正数。
matlab中函数,strcmp(s1,s2) 判断两个字符串s1和s2是否相同,相同返回true ,不同返回false
散列 (基操如下)
int getID(char *name)
{
int id = 0;
for (int i = 0; i < 3; i++)
{
id = id * 26 + (name[i] - 'A');
}//针对字母的散列操作
/* 这个是对数字的散列操作 */
id = id * 10 + (name[3] - '0');
return id;
}
atoi
这个超赞的!!!
string str = "12345";
int num = atoi (str.c_str());
//实现了直接从char* 或者是string向int 的转化
atof
这也还行,就是有所精度的丢失
string str = "12345";
double num = atof (str.c_str());
string.c_str
string.c_str是Borland封装的String类中的一个函数,它返回当前字符串的首字符地址。
c_str函数的返回值是constchar* 的,不能直接赋值给 char*,所以就需要我们进行相应的操作转化.
比如:
string str;
char data[20];
strcpy(data,(char*)(str.c_str());
fgets()
详解:文章摘自网络
# include <stdio.h>
char *fgets(char *s, int size, FILE *stream);
fgets() 虽然比 gets() 安全,但安全是要付出代价的,代价就是它的使用比 gets() 要麻烦一点,有三个参数。
它的功能是从 stream 流中读取 size 个字符存储到字符指针变量 s 所指向的内存空间。它的返回值是一个指针,指向字符串中第一个字符的地址。
其中:s 代表要保存到的内存空间的首地址,可以是字符数组名,也可以是指向字符数组的字符指针变量名。
size 代表的是读取字符串的长度。
stream 表示从何种流中读取,可以是标准输入流 stdin,也可以是文件流,即从某个文件中读取,这个在后面讲文件的时候再详细介绍。标准输入流就是前面讲的输入缓冲区。所以如果是从键盘读取数据的话就是从输入缓冲区中读取数据,即从标准输入流 stdin 中读取数据,所以第三个参数为 stdin。
那有人会问:“用 fgets() 是不是每次都要去数有多少个字符呢?这样不是很麻烦吗?”不用数!fget() 函数中的 size 如果小于字符串的长度,那么字符串将会被截取;(就是输入了一半,剩下的丢掉了)
如果 size 大于字符串的长度则多余的部分系统会自动用 '\0' 填充。所以假如你定义的字符数组长度为 n,那么 fgets() 中的 size 就指定为 n–1,留一个给 '\0' 就行了。
但是需要注意的是,如果输入的字符串长度没有超过 n–1,那么系统会将最后输入的换行符 '\n' 保存进来,保存的位置是紧跟输入的字符,然后剩余的空间都用 '\0' 填充。所以此时输出该字符串时==printf 中就不需要加换行符 '\n' 了,因为字符串中已经有了。==
所以 fgets() 和 gets() 一样,最后的回车都会从缓冲区中取出来。只不过 gets() 是取出来丢掉,而 fgets() 是取出来自己留着。但总之缓冲区中是没有回车了!所以与 gets() 一样,在使用 fgets() 的时候,如果后面要从键盘给字符变量赋值,那么同样不需要清空缓冲区
char str[90];
fgets(str, 90, stdin);//键入字符
int i=0;
while (str[i] != '\n')
{
i++;
}
str[i] = '\0'; //将\n更改成\0
简单来说:
参数数量比较多,有3个。而fgets相比于gets有一个显著的差别就是fgets会将行末的换行符算到读入的字符串里面。所以相同且正常(输入无错误,缓冲区够大)的情况下,fgets读入的字符串会比gets在末尾'\0'前面多一个换行符;行长度超出缓冲区大小时只读入前 n-1 个字符。
因此,
gets(s);
相当于
fgets(s, sizeof(s), stdin);
if(s[strlen(s) - 1] == '\n') s[strlen(s) - 1] = '\0'; // 去掉换行符
或者是易理解的版本
fgets(str, 100, stdin);
while (str[i] != '\n'){
i++;
}
str[i] = '\0';
sprintf
功能:把格式化的数据写入某个字符串缓冲区。
下面是网络上的实例
#include <stdio.h>
#include <math.h>
int main()
{
char str[80];
sprintf(str, "Pi 的值 = %f", M_PI);
puts(str);
return(0);
}
这里给出我的使用
sprintf(digit, "%d" , sum );
//快速将sum读到数组里面,前面是数组名,中间是格式,最后是数字源,但这样前面是低位,后面是高位
reverse(digit);
//如果需要,可以对新得到的digit进行必要的颠倒,当然reverse需要自己写
//也可以用algorithm的reverse
关于string头文件
1.
#include <cstring> //不可以定义string s;可以用到strcpy等函数
using namespace std;
#include <string> //可以定义string s;可以用到strcpy等函数
using namesapce std;
简单总结一下,以后直接包含进来string头文件就可以了
#include <string.h> //不可以定义string s;可以用到strcpy等函数
2.
1)文件cstring,和string.h对应,c++版本的头文件,包含比如strcpy之类的字符串处理函数
2)文件string.h,和cstring对应,c版本的头文件,包含比如strcpy之类的字符串处理函数
3)文件string,包含std::string的定义,属于STL范畴
4)CString,MFC里的的字符串类
git版本更新指令
git update-git-for-windows