L1-033 出生年 (15 分)
以上是新浪微博中一奇葩貼:“我出生於1988年,直到25歲才遇到4個數字都不相同的年份。”也就是說,直到2013年才達到“4個數字都不相同”的要求。本題請你根據要求,自動填充“我出生於y
年,直到x
歲才遇到n
個數字都不相同的年份”這句話。
輸入格式:
輸入在一行中給出出生年份y
和目標年份中不同數字的個數n
,其中y
在[1, 3000]之間,n
可以是2、或3、或4。注意不足4位的年份要在前面補零,例如公元1年被認爲是0001年,有2個不同的數字0和1。
輸出格式:
根據輸入,輸出x
和能達到要求的年份。數字間以1個空格分隔,行首尾不得有多餘空格。年份要按4位輸出。注意:所謂“n
個數字都不相同”是指不同的數字正好是n
個。如“2013”被視爲滿足“4位數字都不同”的條件,但不被視爲滿足2位或3位數字不同的條件。
輸入樣例1:
1988 4
輸出樣例1:
25 2013
輸入樣例2:
1 2
輸出樣例2:
0 0001
#include<bits/stdc++.h>
using namespace std;
set<int>st;
int main()
{
int n, k, cnt = -1;
scanf("%d%d",&n, &k);
for(int i = n;i <= 10000;i++)
{
cnt++;
int a = i / 1000;
int b = i % 1000 / 100;
int c = i % 100 / 10;
int d = i % 10;
st.insert(a);
st.insert(b);
st.insert(c);
st.insert(d);
if(st.size() == k)
{
printf("%d %04d\n",cnt,i);
return 0;
}
st.clear();
}
return 0;
}
L1-034 點贊 (20 分)
微博上有個“點贊”功能,你可以爲你喜歡的博文點個贊表示支持。每篇博文都有一些刻畫其特性的標籤,而你點讚的博文的類型,也間接刻畫了你的特性。本題就要求你寫個程序,通過統計一個人點讚的紀錄,分析這個人的特性。
輸入格式:
輸入在第一行給出一個正整數N(≤1000),是該用戶點讚的博文數量。隨後N行,每行給出一篇被其點讚的博文的特性描述,格式爲“K F1⋯FK”,其中1≤K≤10,Fi(i=1,⋯,K)是特性標籤的編號,我們將所有特性標籤從1到1000編號。數字間以空格分隔。
輸出格式:
統計所有被點讚的博文中最常出現的那個特性標籤,在一行中輸出它的編號和出現次數,數字間隔1個空格。如果有並列,則輸出編號最大的那個。
輸入樣例:
4
3 889 233 2
5 100 3 233 2 73
4 3 73 889 2
2 233 123
輸出樣例:
233 3
#include<bits/stdc++.h>
using namespace std;
int main()
{
int n, i, j, max, k, t;
scanf("%d",&n);
int a[1100][15];
int b[1001] = {0};
for(i = 0;i < n;i ++)
{
scanf("%d", &a[i][0]);
for(j = 1;j <= a[i][0]; j++)
scanf("%d", &a[i][j]);
}
for(i = 0;i < n; i++)
{
for(j = 1;j <= a[i][0];j++)
b[a[i][j]] ++;
}
max = 0;
for(i = 1000;i >= 1;i--){
if(b[i] > max){
max = b[i];
t = i;
}
}
printf("%d %d",t,max);
return 0;
}
L1-035 情人節 (15 分)
以上是朋友圈中一奇葩貼:“2月14情人節了,我決定造福大家。第2個贊和第14個讚的,我介紹你倆認識…………咱三吃飯…你倆請…”。現給出此貼下點讚的朋友名單,請你找出那兩位要請客的倒黴蛋。
輸入格式:
輸入按照點讚的先後順序給出不知道多少個點讚的人名,每個人名佔一行,爲不超過10個英文字母的非空單詞,以回車結束。一個英文句點.
標誌輸入的結束,這個符號不算在點贊名單裏。
輸出格式:
根據點贊情況在一行中輸出結論:若存在第2個人A和第14個人B,則輸出“A and B are inviting you to dinner...”;若只有A沒有B,則輸出“A is the only one for you...”;若連A都沒有,則輸出“Momo... No one is for you ...”。
輸入樣例1:
GaoXZh
Magi
Einst
Quark
LaoLao
FatMouse
ZhaShen
fantacy
latesum
SenSen
QuanQuan
whatever
whenever
Potaty
hahaha
.
輸出樣例1:
Magi and Potaty are inviting you to dinner...
輸入樣例2:
LaoLao
FatMouse
whoever
.
輸出樣例2:
FatMouse is the only one for you...
輸入樣例3:
LaoLao
.
輸出樣例3:
Momo... No one is for you ...
#include<bits/stdc++.h>
using namespace std;
int main()
{
char a[15], b[15], c[15];
int count = 0;
while(1)
{
scanf("%s",c);
if(c[0] == '.')
break;
count++;
if(count == 2)
strcpy(a,c);
if(count == 14)
strcpy(b,c);
}
if(count < 2)
printf("Momo... No one is for you ...");
else if(count >= 2 && count < 14)
printf("%s is the only one for you...",a);
else if(count >= 14)
printf("%s and %s are inviting you to dinner...",a,b);
return 0;
}
L1-036 A乘以B (5 分)
看我沒騙你吧 —— 這是一道你可以在 10 秒內完成的題:給定兩個絕對值不超過 100 的整數 A 和 B,輸出 A 乘以 B 的值。
輸入格式:
輸入在第一行給出兩個整數 A 和 B(−100≤A,B≤100),數字間以空格分隔。
輸出格式:
在一行中輸出 A 乘以 B 的值。
輸入樣例:
-8 13
輸出樣例:
-104
#include<bits/stdc++.h>
using namespace std;
int main()
{
int a, b;
scanf("%d%d", &a, &b);
printf("%d",a * b);
return 0;
}
L1-037 A除以B (10 分)
真的是簡單題哈 —— 給定兩個絕對值不超過100的整數A和B,要求你按照“A/B=商”的格式輸出結果。
輸入格式:
輸入在第一行給出兩個整數A和B(−100≤A,B≤100),數字間以空格分隔。
輸出格式:
在一行中輸出結果:如果分母是正數,則輸出“A/B=商”;如果分母是負數,則要用括號把分母括起來輸出;如果分母爲零,則輸出的商應爲Error
。輸出的商應保留小數點後2位。
輸入樣例1:
-1 2
輸出樣例1:
-1/2=-0.50
輸入樣例2:
1 -3
輸出樣例2:
1/(-3)=-0.33
輸入樣例3:
5 0
輸出樣例3:
5/0=Error
#include<bits/stdc++.h>
using namespace std;
int main(){
int a, b;
scanf("%d%d",&a, &b);
if(b == 0)
printf("%d/%d=Error\n", a, b);
else if(b > 0){
double product;
product = 1.0 * a / b;
printf("%d/%d=%.2f\n", a, b, product);
}
else if(b < 0){
double product;
product = 1.0 * a / b;
printf("%d/(%d)=%.2f\n", a, b, product);
}
return 0;
}
L1-038 新世界 (5 分)
這道超級簡單的題目沒有任何輸入。
你只需要在第一行中輸出程序員欽定名言“Hello World”,並且在第二行中輸出更新版的“Hello New World”就可以了。
輸入樣例:
無
輸出樣例:
Hello World
Hello New World
#include<bits/stdc++.h>
using namespace std;
int main(){
printf("Hello World\n");
printf("Hello New World\n");
return 0;
}
L1-039 古風排版 (20 分)
中國的古人寫文字,是從右向左豎向排版的。本題就請你編寫程序,把一段文字按古風排版。
輸入格式:
輸入在第一行給出一個正整數N(<100),是每一列的字符數。第二行給出一個長度不超過1000的非空字符串,以回車結束。
輸出格式:
按古風格式排版給定的字符串,每列N個字符(除了最後一列可能不足N個)。
輸入樣例:
4
This is a test case
輸出樣例:
asa T
st ih
e tsi
ce s
#include<bits/stdc++.h>
using namespace std;
int main()
{
int N;
char all[105][105], ch;
for(int i = 0;i < 105;i ++)
for(int j = 0;j < 105;j ++)
all[i][j] = ' ';
char s[1000];//表示null
scanf("%d%c", &N, &ch);
scanf("%[^\n]",s);
int wtf = strlen(s);
int x = 0,y = 0;
for(int i = 0;i < wtf; i++)
{
all[x][y] = s[i];
x++;
if(x == N)
{
x = 0;
y++; //表示是多少行
}
}
if(x == 0)//滿了不久換行了 這個時候應該減少一行
y --;//這樣子就知道有多少列了
for(int i = 0;i < N; i++)
{
for(int j = y;j >= 0; j--)
printf("%c",all[i][j]);
printf("\n");
}
return 0;
}
L1-040 最佳情侶身高差 (10 分)
專家通過多組情侶研究數據發現,最佳的情侶身高差遵循着一個公式:(女方的身高)×1.09 =(男方的身高)。如果符合,你倆的身高差不管是牽手、擁抱、接吻,都是最和諧的差度。
下面就請你寫個程序,爲任意一位用戶計算他/她的情侶的最佳身高。
輸入格式:
輸入第一行給出正整數N(≤10),爲前來查詢的用戶數。隨後N行,每行按照“性別 身高”的格式給出前來查詢的用戶的性別和身高,其中“性別”爲“F”表示女性、“M”表示男性;“身高”爲區間 [1.0, 3.0] 之間的實數。
輸出格式:
對每一個查詢,在一行中爲該用戶計算出其情侶的最佳身高,保留小數點後2位。
輸入樣例:
2
M 1.75
F 1.8
輸出樣例:
1.61
1.96
#include<bits/stdc++.h>
using namespace std;
int main()
{
char ch;
double high,mate = 0;
int n, i;
scanf("%d",&n);
getchar();
while(n--)
{
scanf("%c %lf",&ch,&high);
getchar();
if(ch == 'M')
mate = high / 1.09;
else if(ch == 'F')
mate = high * 1.09;
printf("%.2f\n",mate);
}
return 0;
}