<代码收藏>字定义strlen和strcpy

本文详细介绍了C++中字符串复制和长度计算的底层实现原理及应用技巧,包括使用`strcpyz`和`strlenz`函数进行字符串操作,并通过实例展示了如何在实际编程中灵活运用这些函数。

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

#include <iostream>
#include <ctime>
#include <cstdlib>
#include <cassert>
using namespace std;

char *strcpyz(char* des,const char* src)
{
	assert((des!=NULL)&&(src!=NULL));
	while((*des++=*src++)!='\0')
	{
		;
	}
	return des;

}

int strlenz(const char* str)
{
	assert(str!=NULL);
	int len=0;
	while(*str++!='\0')
	{
		++len;
	}
	return len;
}
void main()
{
   
	char* name="张译成";
	char temp[23];
	strcpyz(temp,name);
	cout<<strlenz(temp)<<endl;

	int a;
	cin>>a;
    
}

实验四 算符优先分析器的构造 1. 实验目的与任务 (1)理解自底向上的语法分析的基本思想。 (2)理解算符优先文法的概念。 (3)掌握算符分析表优先函数的构造。 (4)掌握算符优先分析器的工作原理工作流程。 2. 实验原理 算符优先分析法是一种简单、直观、广为使用的语法分析方法,这种方法特别适用于程序设计语言中的表达式的分析。算符优先分析法就是仿照算术表达式的运算过程而提出的一种自底向上的语法分析方法,它可以分析算符优先文法,分析的基本思想是:根据文法终结符之间的优先关系,通过比较相邻算符的优先次序来确定句型中的最左素短语,并进行归约。 所谓的算符优先文法是指:对算符文法中任意两个终结符对a、b之间至多有一种优先关系成立的文法,而算符文法G中的任何一个产生式中都不包含两个非终结符相邻的情况。对于满足这样条件的文法,我们就可以用算符优先分析法对其进行分析。 确定了符合要求的文法之后,自底向上的分析方法的关键就是如何在当前句型中寻找可归约的子串,算符优先分析法在归约过程中,通过终结符之间的优先关系确定当前的句型中的最左素短语,与非终结符无关,只需知道把当前句型中的最左素短语归约为一非终结符,不必知道该非终结符的名是什么,这样也就去掉了单非终结符的归约,一旦找到最左素短语,就将它归约成一个非终结符。 在算符优先分析法分析过程中,可以设置一个栈S,用来存放归约或者待形成最左素短语的符号串,用一个工作单元a存放当前读入的输入符,归约成功的标志是当读入的输入符是句子的结束符号#时,栈S中只剩下#N。 3. 实验内容 给定一个上下文无关文法G: <常量说明部分>→const<常量定义>{,<常量定义>} <常量定义>→<标识符>=<无符号整数> <无符号整数>→<数>{<数>} <变量说明部分>→{var}01 <标识符>{,<标识符>}:integer;∣{var}01 <标识符>{,<标识符>}:real;∣{var}01 <标识符>{,<标识符>}:boolean; <标识符>→<母>{<母>∣<数>} <语句部分>→<语句>∣<复合语句> <复合语句>→begin <语句>{;begin<语句>end;} end. <语句>→<赋值语句>∣<条件语句>∣<循环语句> <赋值语句>→<标识符>:=<表达式> <表达式>→[+∣-]<项>∣<表达式>+<项>∣<表达式>-<项> <项>→<因子>∣<项>*<因子>∣<项>/<因子> <因子>→<标识符>∣<常量>∣(<表达式>) <常量>→<无符号整数> <条件语句>→if <条件> then <语句> else <语句> <条件>→<表达式><关系运算符><表达式>{(and∣or) <表达式><关系运算符><表达式>} <循环语句>→while (<条件>){(and∣or) (<条件>)} do <语句> <关系运算符>→=∣<∣>∣≤∣≥ <母>→a∣b∣c∣…∣z ∣A∣B∣C∣…∣Z <数>→0∣1∣2∣…∣9 编写程序,构造上述文法G的算符优先分析器,使其能实现如下功能: (1)扫描单词的内部表示形式,按语言的语法规则识别出语法单位(语句等); (2)对各语法单位进行语法检查; (3)若发现单词的组成有错误时,输出有关的出错信息。 给出c语言的代码
最新发布
04-24
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值