如何定义一个函数返回它自己?一个函数以它自己为参数?

SIGXXL 2013-04-25 07:07:13
如题,这两个问题我自己没解决,求大神!!!


对于第一个函数,可以如下方式调用:
f()()()()()()()()()()(); //无限使用()操作符


第二个函数,可以如下调用:
f(((((((()))))))); //无限使用()操作符


使用C或C++,不使用C++的Functor
...全文
826 43 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
43 条回复
切换为时间正序
请发表友善的回复…
发表回复
scutth 2014-03-07
  • 打赏
  • 举报
回复
看着这题的尿性,有点像形式化方法啊。。。
zilaishuichina 2014-03-07
  • 打赏
  • 举报
回复
引用 楼主 xxlblue 的回复:
如题,这两个问题我自己没解决,求大神!!! 对于第一个函数,可以如下方式调用: f()()()()()()()()()()(); //无限使用()操作符 第二个函数,可以如下调用: f(((((((()))))))); //无限使用()操作符 使用C或C++,不使用C++的Functor
我只是很好奇为什么要实现这样的东西? 有什么优势? 还是纯粹是在讨论茴香豆的茴字的四种写法?
lm_whales 2014-03-07
  • 打赏
  • 举报
回复
第一个VC6 不可以,VC9 ,10 似乎可以 第二个用宏实现了也没有意义 不过带参的函数,完全可以用逗号表达式实现,不需要任何其他操作 对于不带参数的函数,关键是C,C++解析括号的时候,会层层分析括号 最终只有一层括号真正起作用. VC6 f(()) 直接调用是错误的,因为外层括号是函数调用表达式的括号. 内层括号被认为参数不合法.
booirror 2014-03-01
  • 打赏
  • 举报
回复
引用 32 楼 mujiok2003 的回复:
第一个,使用类型转换函数operator T

struct helper
{
  typedef helper (*pFunc)(); 
  explicit helper(pFunc p): pf(p){}
  operator pFunc const()
  {
    return pf;
  }
  pFunc pf;
};

helper foo()
{
  //do something useful
  return helper(&foo);
}

int main()
{
  foo()()()()()();
  return 0;
}
请问下,const在这是表示什么意思
zhcosin 2014-03-01
  • 打赏
  • 举报
回复
第一个必须使用仿函数,定义一个类,重载 operaotr()() ,在函数内部 return *this;
gz_qmc 2014-03-01
  • 打赏
  • 举报
回复
我想请问,这样实现了之后,在哪方面有用呢?
mujiok2003 2014-03-01
  • 打赏
  • 举报
回复
引用 39 楼 booirror 的回复:
[quote=引用 32 楼 mujiok2003 的回复:] 第一个,使用类型转换函数operator T

struct helper
{
  typedef helper (*pFunc)(); 
  explicit helper(pFunc p): pf(p){}
  operator pFunc const()
  {
    return pf;
  }
  pFunc pf;
};

helper foo()
{
  //do something useful
  return helper(&foo);
}

int main()
{
  foo()()()()()();
  return 0;
}
请问下,const在这是表示什么意思[/quote] 函数内部不修改对象状态
mujiok2003 2013-10-09
  • 打赏
  • 举报
回复
以自己为参数的函数有必要吗? 这个参数的值永远不会变,使用递归就好。

void foo()
{
  //do useful things here and terminate as needed
  foo();
}
unituniverse2 2013-10-09
  • 打赏
  • 举报
回复
绝对不用宏的方法有没有?
unituniverse2 2013-10-09
  • 打赏
  • 举报
回复
至于第二个,C++中目前只发现可以用宏。。。

#define M(a)

int main(void)
{
	M((((()))));
	return 0;
}
mujiok2003 2013-10-09
  • 打赏
  • 举报
回复
第一个,使用类型转换函数operator T

struct helper
{
  typedef helper (*pFunc)(); 
  explicit helper(pFunc p): pf(p){}
  operator pFunc const()
  {
    return pf;
  }
  pFunc pf;
};

helper foo()
{
  //do something useful
  return helper(&foo);
}

int main()
{
  foo()()()()()();
  return 0;
}
baihacker 2013-10-09
  • 打赏
  • 举报
回复
引用 30 楼 unituniverse2 的回复:
注意那个Y组合子的建议貌似这里无用。里面有λ表达式,而它其实是匿名对象的坊函数。所以显然也不能用在这里
我发言中有说明: delegate T SelfApplicable<T>(SelfApplicable<T> self); SelfApplicable<Func<Func<Func<int, int>, Func<int, int>>, Func<int, int>>> 这里SelfApplicable<T>貌似是c#里参数是自己的东西。 至于Y组合子神马的,和LZ的问题问题无直接联系。
unituniverse2 2013-10-09
  • 打赏
  • 举报
回复
注意那个Y组合子的建议貌似这里无用。里面有λ表达式,而它其实是匿名对象的坊函数。所以显然也不能用在这里
unituniverse2 2013-10-09
  • 打赏
  • 举报
回复
引用 27 楼 xxlblue 的回复:
[quote=引用 25 楼 unituniverse2 的回复:] [quote=引用 24 楼 xxlblue 的回复:] [quote=引用 23 楼 unituniverse2 的回复:] 好吧我一个个告诉你: 第一个:

#include "stdafx.h"

class A
{
public:
	A operator () (const A & arg) { return(arg); };
	A operator () (void) { return(A()); };
};

int _tmain(int /*argc*/, _TCHAR* /*argv*/[])//看到这行别觉得不舒服。。别扯远了话题
{
	A f;

	f()()()()()();
	return 0;
}
好吧,我已经说了不允许使用Functor了... 用functor,谁都会的。[/quote] 当时写了发帖后才发现,帖子自己没法编辑了。。 [/quote][/quote] 看清楚哈,这里虽然用了类但肯定不是坊函数了


class A;

A func(void);

typedef A (* A_Ret)(void);

class A
{
public:
	operator A_Ret (void) const { return(&func); };
};

A func(void) { return A(); };


int _tmain(int /*argc*/, _TCHAR* /*argv*/[])
{
	func()()()()()()();
	return 0;
}
baihacker 2013-10-09
  • 打赏
  • 举报
回复
Y组合子的推导及C++实现 LZ的第二个问题在上面的c#代码中。
SIGXXL 2013-10-09
  • 打赏
  • 举报
回复
引用 25 楼 unituniverse2 的回复:
[quote=引用 24 楼 xxlblue 的回复:] [quote=引用 23 楼 unituniverse2 的回复:] 好吧我一个个告诉你: 第一个:

#include "stdafx.h"

class A
{
public:
	A operator () (const A & arg) { return(arg); };
	A operator () (void) { return(A()); };
};

int _tmain(int /*argc*/, _TCHAR* /*argv*/[])//看到这行别觉得不舒服。。别扯远了话题
{
	A f;

	f()()()()()();
	return 0;
}
好吧,我已经说了不允许使用Functor了... 用functor,谁都会的。[/quote] 当时写了发帖后才发现,帖子自己没法编辑了。。 [/quote]
  • 打赏
  • 举报
回复
mark 慢慢看。
unituniverse2 2013-10-09
  • 打赏
  • 举报
回复
引用 24 楼 xxlblue 的回复:
[quote=引用 23 楼 unituniverse2 的回复:] 好吧我一个个告诉你: 第一个:

#include "stdafx.h"

class A
{
public:
	A operator () (const A & arg) { return(arg); };
	A operator () (void) { return(A()); };
};

int _tmain(int /*argc*/, _TCHAR* /*argv*/[])//看到这行别觉得不舒服。。别扯远了话题
{
	A f;

	f()()()()()();
	return 0;
}
好吧,我已经说了不允许使用Functor了... 用functor,谁都会的。[/quote] 当时写了发帖后才发现,帖子自己没法编辑了。。
SIGXXL 2013-10-09
  • 打赏
  • 举报
回复
引用 23 楼 unituniverse2 的回复:
好吧我一个个告诉你: 第一个:

#include "stdafx.h"

class A
{
public:
	A operator () (const A & arg) { return(arg); };
	A operator () (void) { return(A()); };
};

int _tmain(int /*argc*/, _TCHAR* /*argv*/[])//看到这行别觉得不舒服。。别扯远了话题
{
	A f;

	f()()()()()();
	return 0;
}
好吧,我已经说了不允许使用Functor了... 用functor,谁都会的。
yiyefangzhou24 2013-07-06
  • 打赏
  • 举报
回复
fun() { fun() }
加载更多回复(21)
资源下载链接为: https://pan.quark.cn/s/abbae039bf2a 在计算机视觉领域,实时目标跟踪是许多应用的核心任务,例如监控系统、自动驾驶汽车和无人机导航等。本文将重点介绍一种在2017年备受关注的高效目标跟踪算法——BACF(Boosted Adaptive Clustering Filter)。该算法因其卓越的实时性和高精度而脱颖而出,其核心代码是用MATLAB编写的。 BACF算法全称为Boosted Adaptive Clustering Filter,是基于卡尔曼滤波器改进的一种算法。传统卡尔曼滤波在处理复杂背景和目标形变时存在局限性,而BACF通过引入自适应聚类和Boosting策略,显著提升了对目标特征的捕获和跟踪能力。 自适应聚类是BACF算法的关键技术之一。它通过动态更新特征空间中的聚类中心,更准确地捕捉目标的外观变化,从而在光照变化、遮挡和目标形变等复杂情况下保持跟踪的稳定性。此外,BACF还采用了Boosting策略。Boosting是一种集成学习方法,通过组合多个弱分类器形成强分类器。在BACF中,Boosting用于优化目标检测性能,动态调整特征权重,强化对目标识别贡献大的特征,从而提高跟踪精度。BACF算法在设计时充分考虑了计算效率,能够在保持高精度的同时实现快速实时的目标跟踪,这对于需要快速响应的应用场景(如视频监控和自动驾驶)至关重要。 MATLAB作为一种强大的数学计算和数据分析工具,非常适合用于算法的原型开发和测试。BACF算法的MATLAB实现提供了清晰的代码结构,方便研究人员理解其工作原理并进行优化和扩展。通常,BACF的MATLAB源码包含以下部分:主函数(实现整个跟踪算法的核心代码)、特征提取模块(从视频帧中提取目标特征的子程序)、聚类算法(实现自适应聚类过程)、Boosting算法(包含特征权重更新的代
内容概要:本书《Deep Reinforcement Learning with Guaranteed Performance》探讨了基于李雅普诺夫方法的深度强化学习及其在非线性系统最优控制中的应用。书中提出了一种近似最优自适应控制方法,结合泰勒展开、神经网络、估计器设计及滑模控制思想,解决了不同场景下的跟踪控制问题。该方法不仅保证了性能指标的渐近收敛,还确保了跟踪误差的渐近收敛至零。此外,书中还涉及了执行器饱和、冗余解析等问题,并提出了新的冗余解析方法,验证了所提方法的有效性和优越性。 适合人群:研究生及以上学历的研究人员,特别是从事自适应/最优控制、机器人学和动态神经网络领域的学术界和工业界研究人员。 使用场景及目标:①研究非线性系统的最优控制问题,特别是在存在输入约束和系统动力学的情况下;②解决带有参数不确定性的线性和非线性系统的跟踪控制问题;③探索基于李雅普诺夫方法的深度强化学习在非线性系统控制中的应用;④设计和验证针对冗余机械臂的新型冗余解析方法。 其他说明:本书分为七章,每章内容相对独立,便于读者理解。书中不仅提供了理论分析,还通过实际应用(如欠驱动船舶、冗余机械臂)验证了所提方法的有效性。此外,作者鼓励读者通过仿真和实验进一步验证书中提出的理论和技术。

65,186

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧