PTA 1139 1138 1137 1136

PAT 1139 1138 1137 1136

一个月不写题,有点生疏。。脑子跟不上手速,还可以啦,反正今天很开心。

PAT 1139 First Contact

18/30 找个时间再修bug
23/30
28/30
30/30 补完啦

这道题的细节坑点:
	1.输出id需要补全4位  用print("%04d")  5分ok
	2.需要舍弃查询的相恋男女的直接边 3分ok
	3.大坑 0000 与 -0000 使用int型无法区分男女的. 2分ok   想法:用string输入 看长度和第一位符号位 判0和-0 转int 

思路:图论,找男女相恋的中间人。

#include<bits/stdc++.h>
using namespace std;

/*
细节坑点:
	1.输出id需要补全4位  用print("%04d")  5分ok
	2.需要舍弃查询的相恋男女的直接边 3分ok
	3.大坑 0000 与 -0000 使用int型无法区分男女的. 2分ok   想法:用string输入 看长度和第一位符号位 判0和-0 转int 
*/ 

const int maxn = 10000;
vector<int> g[maxn];
int gender[10010];
int n,m;
vector<pair<int,int> >ans;

void init(){
	for(int i=0;i<=10000;i++) gender[i] = 0;
}

bool cmp(pair<int,int> a,pair<int,int> b){
	if(a.first == b.first) return a.second < b.second;
	return a.first < b.first;
}

int stringToAbsInt(string s){
	int x = 0;
	int flag = 0;
	if(s.length() == 5){
		flag = 1;
		for(int i=1;i<s.length();i++) x = x * 10 + (s[i]-'0');
	}else{
		flag = 0;
		for(int i=0;i<s.length();i++) x = x * 10 + (s[i]-'0');
	}
	if(flag){
		gender[x] = 1;
	}else{
		gender[x] = 0;
	}
	return abs(x);
}

int main(){
	cin>>n>>m;
	init();
	for(int i=1;i<=m;i++){
//		int u,v;
		string uu,vv;
		cin>>uu>>vv;
		int absu = stringToAbsInt(uu);
		int absv = stringToAbsInt(vv);
		g[absu].push_back(absv);
		g[absv].push_back(absu);
	}
	int k;
	cin>>k;
	for(int i=1;i<=k;i++){
		int u,v;
		cin>>u>>v;
		int absu = abs(u);
		int absv = abs(v);
		int genderu = gender[absu];
		int genderv = gender[absv];
		int cnt = 0;
		for(int c=0;c<g[absu].size();c++){
			int cc = g[absu][c];
			if(cc == absv) continue; //舍弃 v是u的直接朋友的边 
			if(gender[cc] != genderu ) continue;
			for(int d=0;d<g[absv].size();d++){
				int dd = g[absv][d];
				if(dd == absu) continue; //舍弃 u是v的直接朋友的边
				if(gender[dd] != genderv ) continue;  
				bool flag = false;
				for(int pos = 0;pos<g[cc].size();pos++){
					if(g[cc][pos] == dd){
						flag = true;
						break;
					}
				}
				if(flag){
					cnt++;
					ans.push_back(make_pair(g[absu][c],g[absv][d]));
				}
			}
		}
		cout<<cnt<<endl;
		sort(ans.begin(),ans.end(),cmp);
		for(int i=0;i<cnt;i++){
			printf("%04d %04d\n",ans[i].first,ans[i].second); //输出补全4位 
		}
		ans.clear();
	}
	return 0;
}

1138 Postorder Traversal

数据结构,二叉树先序中序建树后后序遍历

#include<bits/stdc++.h>
using namespace std;

const int maxn = 50010;
int n;
int pre[maxn];
int in[maxn];
int post[maxn];
bool flag = false;

struct node{
	int v;
	struct node *l;
	struct node *r;
};

//建树
node* build(int l,int r,int rootIdx){
	if(l > r) return NULL;
	node *root = new node();
	root->v = pre[rootIdx];
	int pos = l;
	while(in[pos] != pre[rootIdx]) pos++;
	root->l = build(l,pos-1,rootIdx+1);
	root->r = build(pos+1,r,rootIdx+(pos-l+1));
	return root;
}

//后序遍历 打印第一个被遍历的 结点值
void postTravel(node *Root){
	if(flag) return;
	if(Root->l == NULL && Root->r == NULL){
		cout<<Root->v<<endl;
		flag = true;
		return;
	}
	if(Root->l) postTravel(Root->l);
	if(Root->r) postTravel(Root->r);
	return;
}

int main(){
	cin>>n;
	for(int i=1;i<=n;i++) cin>>pre[i];
	for(int i=1;i<=n;i++) cin>>in[i];
	node *Root = new node();
	Root = build(1,n,1); //建树
	postTravel(Root);
	return 0;
}

1137 Final Grading

数据结构,map,排序常见题型

#include<bits/stdc++.h>
#include<unordered_map>
using namespace std;

const int maxn = 10010;
int p; //P the number of students having done the online programming assignmen
int m; //the number of students on the mid-term list
int n; //the number of students on the final exam list

struct student{
	string id;
	int gp;
	int gmid;
	int gfinal;
	int g;
};

unordered_map<string,student > mp;
vector<student> ans;

bool cmp(student stua,student stub){
	if(stua.g == stub.g){
		return stua.id < stub.id;
	}
	return stua.g > stub.g;
}

void print(){
	for(int i=0;i<ans.size();i++){
		cout<<ans[i].id<<" "<<ans[i].gp<<" "<<ans[i].gmid<<" "<<ans[i].gfinal<<" "<<ans[i].g<<endl;
	}
}

void input(){
	cin>>p>>m>>n;
	for(int i=1;i<=p;i++){
		string id;
		int gp;
		cin>>id>>gp;
		mp[id].id = id;
		mp[id].gp = gp;
		mp[id].gmid = -1;
		mp[id].gfinal = -1;
		mp[id].g = -1;
	}
	for(int i=1;i<=m;i++){
		string id;
		int gmid;
		cin>>id>>gmid;
		mp[id].gmid = gmid;
	}
	for(int i=1;i<=n;i++){
		string id;
		int gfinal;
		cin>>id>>gfinal;
		mp[id].gfinal = gfinal;
	}
}

int main(){
	input(); 
	for(auto it = mp.begin();it!=mp.end();it++){
		if(it->second.gp < 200) continue;
//		if(it->second.gfinal < 60 || it->second.gfinal > 100) continue; //吼吼 一开始题意理解错啦 g才是final score 
		if(it->second.gmid > it->second.gfinal) {
			int tempScore = ((it->second.gmid*4 + it->second.gfinal*6) );
			if(tempScore % 10 >= 5) it->second.g = tempScore/10+1;
			else it->second.g= tempScore/10;	
		}
		else it->second.g = it->second.gfinal;
		if(it->second.g >= 60 && it->second.g <=100) ans.push_back(it->second);
	}
	sort(ans.begin(),ans.end(),cmp);
	print();
	return 0;
} 

1136 A Delayed Palindrome

大数模拟加法进位

#include<bits/stdc++.h>
using namespace std;

vector<int> v1;
vector<int> v2;
vector<int> ans;
/*
	reverse
	add
*/

void print(){
	for(int i=0;i<v1.size();i++) cout<<v1[i];
	cout<<" + ";
	for(int i=0;i<v2.size();i++) cout<<v2[i];
	cout<<" = ";
	for(int i=0;i<ans.size();i++) cout<<ans[i];
	cout<<endl; 
} 

bool check(){
	int len = ans.size();
	for(int i=0;i<len/2;i++){
		if(ans[i] != ans[len-i-1]) return false;
	}
	return true;
}

void clear(){
	v1.clear();
	v2.clear();
	for(int i=0;i<ans.size();i++) v1.push_back(ans[i]);
	ans.clear();
}
	
int main(){
	int d;
	while(scanf("%1d",&d)!=EOF) v1.push_back(d);
	int t = 0;
	bool flag = false;
	while((t++) < 10){
		for(int i=0;i<v1.size();i++) ans.push_back(v1[i]);
		if(check()){
			for(int i=0;i<ans.size();i++) cout<<ans[i];
			cout<<" is a palindromic number.";
			flag = true;
			break;
		}
		ans.clear();
		int ci = 0;
		for(int i=0;i<v1.size();i++) v2.push_back(v1[i]);
		reverse(v2.begin(),v2.end());
        //大数加法模拟
		for(int i=v1.size()-1;i>=0;i--){
			int si = v1[i] + v2[i] + ci;
			if(si >= 10) {
				ci = si/10; 
				si = si%10;
			}else{
				ci = 0;
			}
			ans.push_back(si);
		}
		if(ci!=0) ans.push_back(ci);
		reverse(ans.begin(),ans.end());//反转才是 结果和
		ci = 0;
		print();
		if(check()){
			for(int i=0;i<ans.size();i++) cout<<ans[i];
			cout<<" is a palindromic number.";
			flag = true;
			break;
		}
		clear();
	}
	if(flag == false) cout<<"Not found in 10 iterations."<<endl;
	return 0;
} 
posted @ 2019-11-28 23:07  fishers  阅读(335)  评论(0编辑  收藏  举报