acm刷题为什么没java_ACM刷题之路(二)谈谈我对ACM的理解

(2020年2月新增)

这篇文章是我在大一下学期(2018年4月)写的,那时候看见我身边的ACMer写做题总结用了博客,然后我也很快加入了进来。后来在做题的时候,遇到那些不太会的ACM题目,会多做几遍,然后有时间就写个总结,以便以后遇到类似的题能够得心应手。

现在大三了,回想起大一大二的那一部分ACM的难忘经历,确实很感谢蔡老师,也感谢当初能把我招进实验室的15、16级的学长学姐们。

我大致总结一下,加入ACM实验室的优势:

加入ACM,能融入到更优秀的交际圈,从而使你变的优秀。(这点非常重要)

加入ACM,才有机会参加各种程序设计竞赛,一者是提高自己编程水平;二者是获取一定能力分,有利于拿奖学金;三者也是以后就业的闪光点。

加入ACM,确实可以锻炼一个人的自学能力和自制力。超前学习,可以让你在后续的课程中有很大的优势,比如《数据结构》、《C语言程序设计》、《JAVA程序设计》。

加入ACM,会使你的大学四年更加充实。别人忙着在学生会社团奔波的时候,着迷打游戏的时候,刷刷题,真实提升自己的level。

总之,我相信,将来的你,一定会感谢现在拼命的自己。

2018年4月 ACM实验室晚自习学习内容总结:

1.String类型 头文件  #include  c++ 数据类型

不能用gets()读入 只能用cin读入;

Sting相当于数组无限;

2.getline(cin,line);line为string类型定义

vc6.0  两次回车修复:

头文件:两个: #include    #include

今天看C++Primer的时候发现一个问题,getline需要输入2次回车才会显示结果,上网找了一下,发现是VC6.0的原因,修复原因如下:

(1)建立一个1.CPP

(2)输入#include

(3)右击,选择“打开文档”

(4)用CTRL+F查找 else if (_Tr::eq((_E)_C, _D))

(5)

else if (_Tr::eq((_E)_C, _D))

{_Chg = true;

_I.rdbuf()->snextc();

break; }

将上面的代码修改为:

else if (_Tr::eq((_E)_C, _D))

{_Chg = true;

// _I.rdbuf()->snextc();

// (this comments out the defective instruction)

_I.rdbuf()->sbumpc(); // corrected code

break; }

保存退出后即可修复这个问题。

3.stringstream ss(line);

stringstream不会主动释放内存(或许是为了提高效率),但如果你要在程序中用同一个流,反复读写大量的数据,将会造成大量的内存消 耗,因些这时候,需要适时地清除一下缓冲 (用 stream.str("") )stringstream ss(a);代表把string类型的a,替代成ss,ss又可以给其他int等变量,以空格为界,实现功能。

例子:

#include

#include

using namespace std;

int main()

{

string a;

while(getline(cin,a))

{

int sum=0;

int x;

stringstream ss(a);

while(ss>>x)

{

sum+=x;

}

cout<

}

return 0;

}

4.swap交换函数:

1.

void swap2(int &x,int &y)

{

int t;

t=x;

x=y;

y=t;

}

2.

void swap2(int *x,int *y)

{

int t;

t=*x;

*x=*y;

*y=t;

}

5.sort函数,从大到小排  函数:

bool ss(int a,int b)

{

return a>b;

}

函数加一个参数; sort(a,a+5,ss);

6.STL中unique函数的用法

unique的功能是去除相邻的重复元素(只保留一个),把重复的元素移到后面去了;结合sort函数来用,达到去重效果;

#include

#include

using namespace std;

int main()

{

int a[20];

int i;

int len;

for( i=0;i<7;i++)

{

cin>>a[i];

}

sort(a,a+7);

len=unique(a,a+7)-a;

for( i=0;i

{

cout<

}

cout<

return 0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值