数组的区间输出算法,回帖有分

samuellei 2015-08-23 08:02:29
输入:有数组A,元素都是整形数,已经从小到大排序
输出:连续内容以-连接输入,并且以“,”分隔
示例:
1 2 3 4 7 9 10
1-4, 7, 9-10
使用模板库实现。
...全文
183 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
GKatHere 2015-08-24
  • 打赏
  • 举报
回复
嗯, 不妥不妥, long dif = t[n] - t[n-1];会数据溢出。 long dif = t[n] == t[n-1] +1 ? 1 : t[n-1] == t[n] +1 ? -1 : 0; sign 一样; 所以应该重载 T& (+)(long), bool (==)(T&, T&)
GKatHere 2015-08-24
  • 打赏
  • 举报
回复
呵呵, 写了个模版函数

template<class T>		//	T: 重载 ostream& (<<)(ostream&, T&), 重载 long (-)(T&, T&)
bool So(T* t, size_t count)
{
	if (!t || !count )
		return false;
	long sign = t[1] - t[0];
	sign = sign == 1 ? 1 : sign == -1 ? -1 : 0;
	cout << t[0];
	for (size_t n = 1; n < count; n++)
	{
		long dif = t[n] - t[n-1];
		if (!dif || dif != sign)
		{
			if (sign)
				cout << " - " << t[n-1];
			sign = dif == 1 ? 1 : dif == -1 ? -1 : 0;
			if (!sign)
			cout << ", " << t[n];
		}
	}
	if (sign)
		cout << " - " << t[count-1];
	return 1;
}

int _tmain(int argc, _TCHAR* argv[])
{
	long a[] = {1, 2, 3, 4, 7, 8, 8, 9, 10, 11, 12, 67, 55, 54, 53, 52, 50, 99, 85, 10, 9, 8, 7,7 ,7, 7 };
	So(a, _countof(a));

	return 0;
}
zilaishuichina 2015-08-24
  • 打赏
  • 举报
回复
啥叫模板库 STL算模板库么
mujiok2003 2015-08-23
  • 打赏
  • 举报
回复
参考一下 没有做成完全的编译期运算, 我相信那代码不好写且可读性很差。
virtualdarkness 2015-08-23
  • 打赏
  • 举报
回复
遍历下不就完事了吗?

64,654

社区成员

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

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