参考文章(置于最上以表尊重)
【Educoder作业】C&C++指针实训_JZYshuraK的博客-CSDN博客
C++:去掉字符串首尾空格_微风可凉的博客-CSDN博客_c++去除字符串首尾空格
注意指针指向的位置和指向位置对应的值
同时空字符‘\0’与空格不一样,注意判断条件。
#include
using namespace std;
#define _CRT_SECURE_NO_WARNINGS
char * trim(char * str);
int main()
{
char s[1024]; // 定义存储字符串的一维字符数组
// 输入一行字符,可以包含空格
// 输入的字符串存入s中,最多读取个字符,后面自动加上'\0'
cin.getline(s,1024);
cout << trim(s) << endl; // 输出去掉首尾空格后的字符串
return 0;
}
// 函数trim:去掉字符串首尾空格
// 参数:str-字符指针,指向输入的字符串
// 返回值:字符指针,指向去掉首尾空格后的字符串(首地址)
// 提示:可以直接在字符串str中操作
char * trim(char * str)
{
// 请在此添加代码,实现函数trim
/********** Begin *********/
int l = 0;
char *ptr = str;
//ptr指向最后的'\0',l为长度
while (*ptr != '\0') {
ptr ++ ;
}
ptr--;
//把末尾的空格变成'\0'
while(*ptr==' ' && ptr>=str ){
*ptr='\0';
ptr--;
}
//将指针位置调到第一个不是空格的位置处
ptr=str;
while(*ptr==' '){
ptr++;
if (*ptr!=' '){
break;
}
}
return ptr;
/********** End **********/
}
#include
using namespace std;
void pswap(int * p, int *q);
int main()
{
int a, b;
cin >> a >> b; // 输入两个整数
pswap(&a,&b); // 调用pswap函数,交换a、b的值
cout << a << " " << b << endl; // 输出a、b的值
return 0;
}
//函数pswap:交换指针p和q指向的单元中的整数值
//参数:p,q-int类型指针,指向要交换的整数
void pswap(int * p, int *q)
{
// 请在此添加代码,实现函数pswap
/********** Begin *********/
int temp=*p;
*p=*q;
*q=temp;
/********** End **********/
}
我们在函数中是指针指向的值进行转变,而不是一种地址互换(比较抽象)。我一开始使用的做法如下:(想实现一个地址互换)
void pswap(int * p, int *q)
{
// 请在此添加代码,实现函数pswap
/********** Begin *********/
int* temp=p;
p=q;
q=temp;
/********** End **********/
}
实现地址互换并不会对值发生改变,因为最后输出的还是a,b
我的思路是先找出前面是否存在‘-’,并找出‘-’的位置。在这里一共设置了2个指针,一个用于给s修改取值,一个用来遍历s,寻找数字的位置,到‘\0’停止。
#include
using namespace std;
void extractNum(char * str);
int main()
{
char s[1024];
cin.getline(s,1024); // 输入一行字符
extractNum(s); // 调用extractNum函数,选出数字
cout<='0' && *ptr<='9'){
break;
}
count++;
ptr++;
}
char* q0;
int flag=0;
for (int i=0;i<=count;i++){
if (str[i]=='-') {
flag=1;
q0=&str[i];
break;
}
}
//给按顺序赋值
if(flag) {
*p=*q0;
p++;
}
for (int i=1;i<1024;i++){
if(*ptr >= '0' && *ptr <= '9'){
*p=*ptr;
p++;
}
ptr++;
if(*ptr=='\0'){
break;
}
}
*p='\0';
/********** End **********/
}
利用指针边遍历字符串边修改值。
#include
using namespace std;
void toUp(char * str);
int main()
{
char s[1024];
cin.getline(s,1024); // 输入一行字符
toUp(s); // 调用toUp函数,转换成大写字母
cout<='a' && *p<='z'){
*p=*p+'A'-'a';
}
p++;
}
/********** End **********/
}
在使用字符串函数时记得加上#include
// 包含字符串函数库
#include
#include
using namespace std;
int frequency(char * substr, char * str);
int main()
{
char sub[128],str[1024];
cin.getline(sub,128); // 输入子串
cin.getline(str,1024); // 输入长串
int n = frequency(sub,str); // 调用frequency函数,计算子串在长串中出现的次数
cout<
下面为常用字符串函数表。
char * strcpy(char *dest,const char *src) |
将字符串 src 复制到 dest |
char * strcat(char *dest,const char *src) |
将字符串 src 添加到 dest 末尾 |
char * strchr(const char *s,int c) |
检索并返回字符 c 在字符串 s 中第一次出现的位置 |
int strcmp(const char *s1,const char *s2) |
比较字符串 s1 与 s2 的大小,若 s1 串大于 s2 串则返回一个大于 0 的值;若 s1 串等于 s2 串则返回值为 0;若 s1 串小于 s2 串则返回一个小于 0 的值。 |
size_t strlen(const char *s) |
返回字符串 s 的长度 |
char * strncat(char *dest,const char *src,size_t n) |
将字符串 src 中最多 n 个字符复制到字符串 dest 中 |
int strncmp(const char *s1,const char *s2,size_t n) |
比较字符串 s1 与 s2 中前 n 个字符 |
char * strncpy(char *dest,const char *src,zise_t n) |
复制 src 中的前 n 个字符到 dest 中 |
char * strstr(const char *s1,const char *s2) |
扫描字符串 s1,并返回第一次出现 s2 的位置 |
char * strtok(char *s1,const char *s2) |
检索字符串 s1,该字符串 s1 是由字符串 s2 中定义的定界符所分隔 |
本想着要使用strcopy函数的,但是直接用指针进行赋值就行。
#include
using namespace std;
#include
void strmncpy(char *s, int m, int n, char *t);
int main()
{
char s[128],t[128];
int m,n;
cin>>s; // 输入源串
cin>>m>>n; // 输入m和n
strmncpy(s, m, n, t); // 字符串复制
cout << t <