第十六周项目2-用指针玩字符串(补充)

本文介绍了使用C++进行字符串操作的方法,包括去除特定字符、获取字符串长度、统计单词数量、去除多余空格以及字符串比较等功能的实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

指针是神奇的,指向整型的指针int *p1,可以操作整型数组int a[];指向字符型的指针char *p2,可以操作字符数组(字符串)char str[];更灵活的是,在函数的传递中,指针、数组名在一定程度上可以互换。请编制函数,对字符串的进行各种操作。


去除字符串str中的特定字符c(如空格),结果仍保存到原字符串中

/*
* Copyright (c) 2014,烟台大学计算机学院
* All right reserved.
* 作者:邵帅
* 文件:demo.cpp
* 完成时间:2014年12月15日
* 版本号:v1.0
*/
#include <iostream>
using namespace std;
char *pdelchar(char *str, const char c);
int main(){
    char s1[50]="Hello world. ";
    char s2[50]="Good morning. ";
    char s3[50]="vegetable bird! ";
    pdelchar(s1,' ');
    cout<<"去除空格后:"<<s1<<endl;
    return 0;
}
char *pdelchar(char *str, const char c)
{
   char *p=str,*q=str;
	for(;*q!='\0';q++)
	{
		if(*q!=c)
		{
			*p=*q;
			p++;
		}
	}
	*p='\0';
	return str;
}
运行结果:

求字符串str的长度并返回

/*
* Copyright (c) 2014,烟台大学计算机学院
* All right reserved.
* 作者:邵帅
* 文件:demo.cpp
* 完成时间:2014年12月15日
* 版本号:v1.0
*/
#include <iostream>
using namespace std;
int pstrlen(char *str);
int main()
{
	int n;
    char s1[50]="Hello world. ";
    n=pstrlen(s1);
    cout<<"\""<<s1<<"\""<<"的长度为"<<n<<endl;
    return 0;
}
int pstrlen(char *str)
{
   char *p=str;
   int i=0;
	for(;*p!='\0';p++)
	   i++;
	return i;
}


运行结果:


统计句子str中单词的个数

/*
* Copyright (c) 2014,烟台大学计算机学院
* All right reserved.
* 作者:邵帅
* 文件:demo.cpp
* 完成时间:2014年12月15日
* 版本号:v1.0
*/
#include <iostream>
using namespace std;
int pwordnum(char *str);
int main()
{
	int n;
    char s[50]="Make English easy to learn.";
    n=pwordnum(s);
    cout<<"\""<<s<<"\""<<"的单词数为:"<<n<<endl;
    return 0;
}
int pwordnum(char *str)
{
   char *p=str;
   int i=0;
	for(;*p!='\0';p++)
	   {
	   	if(*p==' ')
	   	 i++;
	   }
	 i++;
	return i;
}


运行结果:


去除句子中所有多余的空格,返回去除了空格的字符串

/*
* Copyright (c) 2014,烟台大学计算机学院
* All right reserved.
* 作者:邵帅
* 文件:demo.cpp
* 完成时间:2014年12月15日
* 版本号:v1.0
*/
#include <iostream>
using namespace std;
char *prim(char *str);
int main()
{
    char s[50]="Make English easy to learn.";
    *prim(s);
    cout<<"去除空格后为:"<<s<<endl;
    return 0;
}
char *prim(char *str)
{
   char *p=str,*q=str;
	for(;*p!='\0';p++)
	   {
	   	if(*p!=' ')
	   	{
	   	 *q=*p;
	   	 *q++;
	   	}
	   }
   *q='\0';
	return str;
}

运行结果:


*比较两个字符串,返回值同strcmp()( 参考贺老)

#include <iostream>
#include <iomanip>
using namespace std;

int pstrcmp(char *str1, char *str2);
int main(void)
{
    char *s[81]= {"Tudou","Shanyaodan","Yangyu","Malingshu"};
    int i=0,j=0;
    cout<<"土豆大PK:"<<endl;
    cout<<setw(12)<<" ";
    for(; i<4; i++)
    {
        cout<<setw(12)<<s[i];
    }
    cout<<endl;
    for(i=0; i<4; i++)
    {
        cout<<setw(12)<<s[i];
        for(j=0; j<4; j++)
        {
            cout<<setw(12)<<pstrcmp(s[i],s[j]);
        }
        cout<<endl;
    }
    return 0;
}


//str>str2,返回1
//str==str2,返回0
//str<str2,返回-1
int pstrcmp(char *str1, char *str2)
{
    char *p=str1,*q=str2;
    while(*p==*q&&*p!='\0'&&*q!='\0')
    {
        p++;
        q++;
    }
    if (*p>*q)
        return 1;
    else if(*p<*q)
        return -1;
    else
        return 0;
}

运行结果:


关于strcmp()

C/C++函数,比较两个字符串。设这两个字符串为str1,str2,若str1==str2,则返回零;若str1>str2,则返回正数;若str1<str2,则返回负数。
原型:extern int strcmp(const char *s1,const char * s2);


当s1<s2时,返回为负数
当s1=s2时,返回值= 0
当s1>s2时,返回正数
即:两个字符串自左向右逐个字符相比(按ASCII值大小相比较),直到出现不同的字符或遇'\0'为止。如:
"A"<"B" "a">"A" "computer">"compare"
特别注意:strcmp(const char *s1,const char * s2)这里面只能比较字符串,不能比较数字等其他形式的参数。

举例代码:

int__cdeclstrcmp(constchar*src,constchar*dst){
intret=0;
while(!(ret=*(unsignedchar*)src-*(unsignedchar*)dst)&&*dst)
++src,++dst;
if(ret<0)
ret=-1;
elseif(ret>0)
ret=1;
return(ret);
}


@ Mayuko




内容概要:本文档《c预约面试大全.pdf》汇集了大量C语言及其相关领域的面试问题与解答,涵盖了从基础概念到高级技巧的广泛知识点。主要内容包括但不限于:C语言的基础语法(如static关键字的作用、指针与引用的区别)、数据结构(如平衡二叉树、链表操作)、算法(如冒泡排序的时间复杂度)、计算机网络(如TCP/IP协议栈)、操作系统(如进程和线程的区别)、内存管理(如堆栈差异)等方面。此外,还涉及了一些较为复杂的主题,例如位域的应用、编译原理中的预编译概念、以及针对特定问题的编程实现(如寻找数组中的重复数字、实现约瑟夫环问题等)。每个问题都配有详细的解释或代码示例,旨在帮助求职者全面准备C语言相关的技术面试。 适合人群:正在准备C语言及相关领域(如嵌入式开发、系统编程)工作的求职者,尤其是有一定编程基础但缺乏实战经验的技术人员。 使用场景及目标:①帮助读者深入理解C语言的核心概念和技术细节;②通过实际案例分析提升解决复杂问题的能力;③为参加各类技术面试做好充分的知识储备和心理准备。 其他说明:此文档不仅包含了理论知识,还提供了大量实战练习的机会,鼓励读者动手实践,从而更好地掌握所学内容。同时,文档中的问题难度逐步递增,适合不同层次的学习者按需选择。由于C语言是许多高级编程语言的基础,因此这份资料对于想要深入学习计算机科学的学生也非常有价值。
内容概要:本文详细介绍了在存在窄带干扰的OFDM航空通信系统中实现多普勒频偏估计与补偿的方法。首先定义了OFDM系统的参数,包括子载波数量、循环前缀长度、信噪比等,并建立了双路径多普勒频偏模型和窄带干扰参数。接着实现了信道模型,包括生成航空通信双路径信道模型、应用多普勒频偏到信号以及添加窄带干扰。然后描述了OFDM信号的生成与接收处理,包括生成OFDM符号、模拟接收过程等。文章还详细介绍了信道估计与频偏估计方法,如最小二乘(LS)、最大似然(ML)信道估计以及差分相关法和双线性多普勒频偏估计。最后,文章讨论了频偏补偿与性能评估,提出了基于SIR最大化的最优补偿方法,并通过仿真验证了算法的有效性。 适合人群:具有通信工程背景的研究人员和技术人员,尤其是从事航空通信系统设计与优化的专业人士。 使用场景及目标:①理解和实现OFDM系统在存在窄带干扰情况下的多普勒频偏估计与补偿;②掌握ML和LS信道估计方法以及差分相关法的应用;③评估不同信道估计方法在窄带干扰下的性能差异。 其他说明:该资源不仅提供了详细的Python代码实现,还通过模块化设计支持性能比较和可视化分析。对于希望深入了解航空通信系统中频偏估计与补偿技术的研究人员来说,这是一个非常有价值的参考资料。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值