大胖的部落格
Just a note
C++博客
::
首页
::
新随笔
::
联系
::
聚合
::
管理
::
112 随笔 :: 0 文章 :: 3 评论 :: 0 Trackbacks
<
2009年7月
>
日
一
二
三
四
五
六
28
29
30
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
1
2
3
4
5
6
7
8
留言簿
给我留言
查看公开留言
查看私人留言
随笔分类
Algorithm(13)
(rss)
C#(13)
(rss)
C++(22)
(rss)
Design Pattern(23)
(rss)
Others(14)
(rss)
STL(9)
(rss)
Technical(2)
(rss)
UML(2)
(rss)
Win32(18)
(rss)
Reference
Windows XP command line
最新评论
1. re: 在TCL命令行中调用C函数
@Kenny
实在不好意思,时间太过久远,本人已好久没有接触TCL……
--大胖
2. re: 在TCL命令行中调用C函数
請問如何溝通array 變數
Q:1
tcl array in C
Q:2
C array in tcl
懇求指導
--Kenny
3. re: 在TCL命令行中调用C函数
谢谢!
--1232
泛型算法
#include
"
stdafx.h
"
#include
<
iostream
>
#include
<
vector
>
#include
<
algorithm
>
using
namespace
std;
//
used for for_each()
void
Out(
const
int
&
i)
{
cout
<<
i
<<
'
'
;
}
//
used for stable_sort()
bool
Less(
const
int
&
a,
const
int
&
b)
{
return
a
<
b;
}
//
used for count_if()
bool
Large(
const
int
&
i)
{
return
i
>
2
;
}
int
main()
{
int
iArray[]
=
{
1
,
1
,
1
,
3
,
2
,
1
,
6
,
7
}
;
vector
<
int
>
vi(iArray, iArray
+
8
);
vector
<
int
>
::iterator it;
//
count()利用等于操作符把[first,last)标记范围内的元素与value 进行比较并返回容器中与value 相等的元素的个数.
int
i
=
(
int
)count(vi.begin(), vi.end(),
1
);
//
count_if()对于[first,last]标记范围内的每个元素都应用第三个参数指向的函数, 并返回计算结果为true的次数
i
=
(
int
)count_if(vi.begin(), vi.end(), Large);
//
stable_sort()保留相等元素的相对位置,stable_sort()能够接受的第三个实参可以是函数的指针也可以是函数对象.
stable_sort(vi.begin(), vi.end());
stable_sort(vi.begin(), vi.end(), Less);
//
unique()去掉容器中相邻的重复值,返回一个iterator 指向这个废弃部分的开始处.
it
=
unique(vi.begin(), vi.end());
//
remove()把元素分成保留的把它们按顺序拷贝到容器的前面和要删除的它们留在后面它返问一个指向要被删除的第一个元素的iterator.
it
=
remove(vi.begin(), vi.end(),
1
);
//
for_each()把函数指针或函数对象应用在由一对iterator 标记的容器的每个元素上.
for_each(vi.begin(), vi.end(), Out);
return
0
;
}
posted on 2009-06-29 10:43
大胖
阅读(187)
评论(0)
编辑
收藏
引用
所属分类:
STL
只有注册用户
登录
后才能发表评论。
【推荐】100%开源!大型工业跨平台软件C++源码提供,建模,组态!
相关文章:
泛型算法
STL六大组件
迭代器
函数对象
auto_ptr
容器-set和map
容器-list
容器-deque
容器-vector
网站导航:
博客园
IT新闻
BlogJava
知识库
博问
管理
Powered by:
C++博客
Copyright © 大胖