PAT基本レベル-ゴールデンランクサンプルボリューム1

最初の3つの質問は古い質問であり、最後の2つの質問は新しい質問です。

7-1寝たふり(10点)

#include<iostream>
using namespace std;
int main(){
    int n,t1,t2;
    string name;
    cin>>n;
    for(int i=0;i<n;i++){
        cin>>name>>t1>>t2;
        if(t1<15||t1>20||t2<50||t2>70)
            cout<<name<<endl;
    }
    return 0;
}

7-2電子王(10ポイント)

#include<iostream>
using namespace std;
int main(){
    int a,b;
    cin>>a>>b;
    int n=a+b;
    while(n--){
    	cout<<"Wang!";	
	}
    return 0;
}

7-3太りすぎですか?(10点)

#include<iostream>
using namespace std;
int main(){
    int n;
    cin>>n;
    double h,w,biaozhun,k;
    for(int i=0;i<n;i++){
    	cin>>h>>w;//w: 市斤=2*公斤
		biaozhun=(h-100)*0.9;//公斤	
		if((w/2-biaozhun)<0){
			if(-1*(w/2-biaozhun)<biaozhun*0.1)
				cout<<"You are wan mei!"<<endl;
			else  cout<<"You are tai shou le!"<<endl;
		}else{
			if((w/2-biaozhun)<biaozhun*0.1)
				cout<<"You are wan mei!"<<endl;
			else  cout<<"You are tai pang le!"<<endl;
		}
	}
    return 0;
}

7-4 2つ(15ポイント)

整数の「有罪2度」は、数字の2の数字とその桁の比率として定義されます。数値が負の場合、次数は0.5倍に増加します。それでも偶数の場合、次数は1倍に増加します。たとえば、その数-13142223336が11桁の数で、3つの2があり、それが負の数であり、それが偶数である場合、その有罪度2は次のように計算されます。3/ 11×1.5×2 ×100%、つまり約81.82%。この質問では、特定の整数が2つであるかどうかを計算するように求められます。

入力フォーマット:

最初の行を入力して、50桁以下の整数を指定しますN

出力フォーマット:

N小数点以下2桁を維持しながら、1行に2つのコミット度を出力します。

入力サンプル:

-13142223336

サンプル出力:

81.82%

コード:

#include<iostream>
#include <cstdio>
#include<cstring>
using namespace std;
int main(){
    string s;
    cin>>s;
    double res=1.0;
    res*=(s[0]=='-')? 1.5:1.0;  //程度1
    res*=((s[s.length()-1]-'0')%2==0)?2:1; //程度2
    int k=0;
    if(s[0]=='-') k=1;
    int cnt=0;
    for(int i=0;i<s.length();i++){
    	if(s[i]=='2')  cnt++;
	}
	res*=(double)cnt/(s.length()-k)*100;
	printf("%.2f%%",res);
	return 0;
}

7-5 1つのグループ(15ポイント)

「1つのグループ、1つの研究グループ」は、小中学校で一般的な学習組織であり、教師は学業成績の高い生徒を学業成績の低い生徒とグループに分けます。この質問については、教師がこの課題を自動的に完了するのに役立つプログラムを作成してください。つまり、クラス全体のランキングを取得した後、現在グループ化されていない生徒の間で、ランキングが最も高い生徒とランクが最も低い異性1つのグループにまとめます。

入力フォーマット:

最初の行を入力して、正の偶数N(≤50)、つまりクラスの生徒数を指定します。その後N、各生徒の性別(女の子は0、男の子は1)と名前(8文字以内の空でない文字列)を高から低の順にスペースで区切って指定します。このクラスの男性と女性の比率は1:1であることが保証されており、同点はありません。

出力フォーマット:

各行には、スペースで区切られた2人の学生のグループの名前が出力されます。上位の学生が一番上にあり、下位の学生が一番下にあります。グループの出力順序は、前の学生のランキングに従って高いものから低いものへと並べられています。

入力サンプル:

8
0 Amy
1 Tom
1 Bill
0 Cindy
0 Maya
1 John
1 Jack
0 Linda

サンプル出力:

Amy Jack
Tom Linda
Bill Maya
Cindy John

 コード:

#include<iostream>
using namespace std;
struct student{
	int sex;
	string name;
	int flag=0;
};
int main(){
	int n,cnt=0;
	cin>>n;
	student stu[n];
	for(int i=0;i<n;i++)
		cin>>stu[i].sex>>stu[i].name;
	for(int i=0;i<n;i++){
		for(int j=n-1;j>=0;j--){
			if(stu[i].sex!=stu[j].sex&&stu[i].flag==0&&stu[j].flag==0)
			{
				stu[i].flag=1;
				stu[j].flag=1;
				cnt+=2;
				cout<<stu[i].name<<" "<<stu[j].name<<endl;
			}
			if(cnt==n) return 0;	
		}
	}
	return 0;
}

細部への注意!

おすすめ

転載: blog.csdn.net/WKX_5/article/details/114301217