其他分享
首页 > 其他分享> > LCY进阶 week1 STL

LCY进阶 week1 STL

作者:互联网

T1链接

题意:把两个集合的元素全部凑到一个集合中,从小到大输出即可;
idea:用set天然带有去重的功能

ACcode:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<map>
#include<set>
#define LL long long
using namespace std;

int n,m,t;

int main()
{
	while( scanf("%d %d",&n,&m)!=EOF )
	{
		set<int> s;
		for(int i=1;i<=n;i++)
		{
			scanf("%d",&t);
			s.insert(t);
		}
		for(int i=1;i<=m;i++)
		{
			scanf("%d",&t);
			s.insert(t);
		}
		int i=0;
		while( s.size()>0 )
		{
			if( i==0 ) printf("%d",( *s.begin() ));
			else printf(" %d",( *s.begin() ));
			s.erase( s.begin() );
			i++;
		}
		cout<<endl;
	}
	return 0;
}

T2链接

题意:给定火车的进站顺序和出栈顺序,问能否做到按进站顺序进然后按出站顺序出去。

idea:栈的经典题了,遍历进站顺序,每次压进去前检查栈顶的元素是否和当前匹配的出栈的车号一样,一样就出栈,直到没有可以出栈的了,再压进去。

PS:输入一定是按字符来输入

ACcode:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<map>
#include<set>
#include<stack>
#define LL long long
#define N 1010
using namespace std;

int n,in[N],out[N],ans[N],len=0;

int main()
{
//	freopen("in.txt","r",stdin);
	while( scanf("%d",&n)!=EOF )
	{
		len = 0;
		char c;
		int j;
		bool pd = true;
		for(int i=1;i<=n;i++)
		{
			cin>>c;
			in[i] = c-'0';
		}
		for(int i=1;i<=n;i++)
		{
			cin>>c;
			out[i] = c-'0';
			
		}
		stack<int> s;
		j = 1;
		for(int i=1;i<=n;i++)
		{
			while( !s.empty() && out[j]==s.top() )
			{
				j++;
				s.pop();
				ans[++len] = 2;
			}
			s.push( in[i] );
			ans[++len] = 1;
		}
		while( j<=n && !s.empty() && out[j]==s.top() )
		{
			ans[++len] = 2;
			j++;
			s.pop();
		}
		if( !s.empty() ) pd = false;
		
		if( pd ) printf("Yes.\n");
		else printf("No.\n");
		
		if( pd ) 
		for(int i=1;i<=len;i++)
		{
			if( ans[i]==1 ) printf("in\n");
			else if(ans[i]==2) printf("out\n");
		}
		printf("FINISH\n");
	}
	return 0;
}

T3 链接

题意:问一堆元素里面剔除重复的元素外一共有几个
iead:set乱搞

ACcode:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<map>
#include<set>
#define LL long long
using namespace std;

int n,ans;
string s;
set<string> sa;

int main()
{
	while( scanf("%d",&n)!=EOF )
	{
		sa.clear();
		for(int i=1;i<=n;i++)
		{
			cin>>s;
			sa.insert(s);
		}	
		printf("%d\n",sa.size());
	}
	return 0;
}

T4链接

题意:一个从小到大排好序的数组,第M字典序小的序列是什么。
idea:STL中的next_permutation(取下一个更大的序列)和prev_permutation(取上一个更小的序列)

ACcode:

#include<iostream>
#include<cstdio>
#include<bits/stdc++.h>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<map>
#include<set>
#define LL long long
#define N 1010
using namespace std;

int n,m,a[N];

int main()
{
//	freopen("in.txt","r",stdin);
	while( scanf("%d %d",&n,&m)!=EOF )
	{
		for(int i=1;i<=n;i++) a[i] = i;
		for(int i=1;i<=m-1;i++)
		{
			next_permutation( a+1,a+n+1 );
		}
		printf("%d",a[1]);
		for(int i=2;i<=n;i++) printf(" %d",a[i]);
		cout<<endl;
	}
	return 0;
}

T5链接

题意:给定一个火星词汇对应的英文,再给几句火星文+英文的句子,要你翻译成全英文。

idae:用map,而且没有给出的词汇直接输出就是(本来就是英文)

PS:注意用getline前的getchar

ACcode:

#include<iostream>
#include<cstdio>
#include<bits/stdc++.h>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<map>
#include<set>
#define LL long long
#define N 1010
using namespace std;

map<string,string>ma;
map<string,string>::iterator it;
string a,b,s;
int n,len;
bool check(char c)
{
	if( ( c>='a'&&c<='z' ) || ( c>='A'&&c<='Z' ) ) return true;
	else return false;
}

int main()
{
//	freopen("in.txt","r",stdin);
	cin>>a;
	while( cin>>a )
	{
		if( a.compare("END")==0 ) break;
		else cin>>b;
		ma[b] = a;
	}
	cin>>a;
	getchar();
	while( 1 )
	{
		getline(cin,s);
		if( s=="END" ) break;
		n = s.size();
		for(int i=0;i<n;i++)
		{
			len = 0;
			char d[1010];
			if( check(s[i]) )
			{
				len = 0;
				for(;i<n;i++)
				{
					if( check(s[i]) ) d[len++] = s[i];
					else break;
				}
				d[len] = '\0';
				if( ma.find(d)!=ma.end() ) cout<<ma[d];
				else cout<<d;
			}
			cout<<s[i];
		}
		cout<<endl;
	}
	return 0;
}

T6 链接

题意:括号匹配…
idea:用栈或者直接扫一遍,遇到’ } ’ 但是没有对应的’ { ’ 了就ans++(把此右括号变成左括号),最后加上还剩下的 左括号数/2就是答案。

ACcode:

#include<iostream>
#include<cstdio>
#include<bits/stdc++.h>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<map>
#include<set>
#define LL long long
#define N 1010
using namespace std;

string s;
int l,h=0,ans;

int main()
{
//	freopen("in.txt","r",stdin);
	while( cin>>s )
	{
		ans = 0;
		l = 0;
		if( s[0]=='-' ) break;
		h++;
		cout<<h<<". ";
		for(int i=0;i<s.size();i++)
		{
			
		if( s[i]=='{' )
		{
			l++;
		}
		else 
		{
			if( l>0 )
			{
				l--;
			}
			else
			{
				ans++;
				l++;
			}
		}
			
		}
		ans += l/2;
		cout<<ans<<endl;
	}
	return 0;
}

标签:进阶,STL,++,long,int,len,ans,week1,include
来源: https://blog.csdn.net/ojzha/article/details/114407785