1,成绩排序
-
题目描述:
-
用一维数组存储学号和成绩,然后,按成绩排序输出。
-
输入:
-
输入第一行包括一个整数N(1<=N<=100),代表学生的个数。
接下来的N行每行包括两个整数p和q,分别代表每个学生的学号和成绩。
-
输出:
-
按照学生的成绩从小到大进行排序,并将排序后的学生信息打印出来。
如果学生的成绩相同,则按照学号的大小进行从小到大排序。
-
样例输入:
-
3 1 90 2 87 3 92
-
样例输出:
-
2 87 1 90 3 92
总结:好吧,我用的还是冒泡排序。。。。
#include<iostream>
using namespace std;
struct student{
int num;
int score;
};
bool compare_stu(struct student s1,struct student s2){
if(s1.score > s2.score){
return true;
}else if(s1.score == s2.score && s1.num > s2.num){
return true;
}
return false;
}
int main(){
int n,i,j;
struct student s[101];
struct student swap;
while(cin>>n){
for(i=0;i<n;i++){
cin>>s[i].num;
cin>>s[i].score;
}
for(i=0;i<n;i++){
for(j=0;j<n-1-i;j++){
if(compare_stu(s[j],s[j+1])){
swap = s[j];
s[j] = s[j+1];
s[j+1] = swap;
}
}
}
for(i=0;i<n;i++){
cout<<s[i].num<<" "<<s[i].score<<endl;
}
}
return 0;
}
2,字符串连接
-
题目描述:
-
不借用任何字符串库函数实现无冗余地接受两个字符串,然后把它们无冗余的连接起来。
-
输入:
-
每一行包括两个字符串,长度不超过100。
-
输出:
-
可能有多组测试数据,对于每组数据,
不借用任何字符串库函数实现无冗余地接受两个字符串,然后把它们无冗余的连接起来。
输出连接后的字符串。
-
样例输入:
-
abc def
-
样例输出:
-
abcdef
#include<iostream>
using namespace std;
int main(){
char str[200];
char str1[101];
char str2[101];
int len1,len2;
int i;
while(cin>>str1 && cin>>str2){
len1=len2=0;
while(str1[len1++]);
while(str2[len2++]);
for(i=0;i<len1-1;i++){
str[i] = str1[i];
}
for(i=0;i<len2-1;i++){
str[len1-1+i] = str2[i];
}
for(i=0;i<len1+len2-2;i++){
cout<<str[i];
}
cout<<endl;
}
return 0;
}