读取一个带有两个小数位的浮点数,这代表货币价值。
在此之后,将该值分解为多种钞票与硬币的和,每种面值的钞票和硬币使用数量不限,要求使用的钞票和硬币的总数量尽可能少。
钞票的面值是 100,50,20,10,5,2
硬币的面值是 1,0.50,0.25,0.10,0.05和0.01
经过实验证明:在本题中,优先使用面额大的钞票和硬币可以保证所用的钞票和硬币总数量最少。
输入一个浮点数 N。
参照输出样例,输出每种面值的钞票和硬币的需求数量。
0≤N≤1000000.000
576.73
NOTAS:
5 nota(s) de R$ 100.00
1 nota(s) de R$ 50.00
1 nota(s) de R$ 20.00
0 nota(s) de R$ 10.00
1 nota(s) de R$ 5.00
0 nota(s) de R$ 2.00
MOEDAS:
1 moeda(s) de R$ 1.00
1 moeda(s) de R$ 0.50
0 moeda(s) de R$ 0.25
2 moeda(s) de R$ 0.10
0 moeda(s) de R$ 0.05
3 moeda(s) de R$ 0.01
#include
#include
using namespace std;
int main()
{
int a1[]={100,50,20,10,5,2};
int a2[]={100,50,25,10,5,1};
double m;
cin>>m;
double s;
s=m;
cout<<"NOTAS:"<
给定一个整数,请根据下表确定并输出其对应的城市名称:
如果输入数字不在上表中,则输出 DDD nao cadastrado
。
共一行,包含一个整数。
输出对应城市名称,如果没有对应城市名称,则输出 DDD nao cadastrado
。
11
Sao Paulo
#include
using namespace std;
int main()
{
int DDD[8] = {61, 71, 11, 21, 32, 19, 27, 31};
string Destination[8] = {"Brasilia", "Salvador", "Sao Paulo", "Rio de Janeiro", "Juiz de Fora", "Campinas", "Vitoria", "Belo Horizonte"};
int n;
cin >> n;
for (int i = 0; i < 8; i ++ )
{
if(n==DDD[i])
{
cout << Destination[i];
break;
}
else if (i==7)
{
cout << "DDD nao cadastrado";
}
}
return 0;
}
读取四个整数 A,B,C,D,用来表示游戏的开始时间和结束时间。
其中 A 和 B 为开始时刻的小时和分钟数,C 和 D为结束时刻的小时和分钟数。
请你计算游戏的持续时间。
比赛最短持续 1分钟,最长持续 24 小时。
共一行,包含四个整数 A,B,C,D。
输出格式为 O JOGO DUROU X HORA(S) E Y MINUTO(S)
,表示游戏共持续了 X� 小时 Y� 分钟。
0≤A,C≤23
0≤B,D≤59
7 8 9 10
O JOGO DUROU 2 HORA(S) E 2 MINUTO(S)
7 7 7 7
O JOGO DUROU 24 HORA(S) E 0 MINUTO(S)
7 10 8 9
O JOGO DUROU 0 HORA(S) E 59 MINUTO(S)
#include
#include
#include
using namespace std;
int main()
{
int a,b,c,d;
cin >> a>>b>>c>>d;
int t=(c*60+d)-(a*60+b);
if(t==0)
{
cout << "O JOGO DUROU 24 HORA(S) E 0 MINUTO(S)"<0)
{
int h=t/60;
int m=t%60;
printf("O JOGO DUROU %d HORA(S) E %d MINUTO(S)",h,m);
}
else if(t<0)
{
int h=(c+24)*60;
int x=(h+d)-(a*60+b);
printf("O JOGO DUROU %d HORA(S) E %d MINUTO(S)",x/60,x%60);
}
return 0;
}
这里用到了sort排序
具体文章在CSDN
C++ sort()排序详解-CSDN博客
读取三个整数并按升序对它们进行排序。
共一行,包含三个整数。
首先,将三个整数按升序顺序输出,每行输出一个整数。
然后,输出一个空行。
紧接着,将三个整数按原输入顺序输出,每行输出一个整数。
−100≤输入整数≤100,
输入整数各不相同。
7 21 -14
-14
7
21
7
21
-14
#include
#include
#include
using namespace std;
int main()
{
int a[3];
int b[3];
for (int i = 0; i < 3; i ++ )
{
cin>>a[i];
b[i]=a[i];
}
sort(a,a+3);
for (int i = 0; i <3; i ++ )
{
cout << a[i]<
输入两个整数 N 和 M,构造一个 N 行 M 列的数字矩阵,矩阵中的数字从第一行到最后一行,按从左到右的顺序依次为 1,2,3,…,N×M。
矩阵构造完成后,将每行的最后一个数字变为 PUM。
输出最终矩阵。
共一行,包含两个整数 N 和 M。
输出最终矩阵,具体形式参照输出样例。
1≤N,M≤20
7 4
1 2 3 PUM
5 6 7 PUM
9 10 11 PUM
13 14 15 PUM
17 18 19 PUM
21 22 23 PUM
25 26 27 PUM
#include
#include
#include
using namespace std;
int main()
{
int x,y;
cin >> x >> y;
int a[x][y];
int s=1;
for(int i=0;i
医学部一共进行了 N 场动物实验。
共有三种小动物可用来实验,分别是青蛙、老鼠和兔子。
每次实验都会选取其中一种动物来参与实验,选取数量若干。
现在请你统计一下医学部一共用了多少小动物,每种分别用了多少,每种动物使用数量占总量的百分比分别是多少。
第一行包含整数 N,表示实验次数。
接下来 N 行,每行包含一个整数 A(表示一次实验使用的小动物的数量)和一个字符 T(表示一次实验使用的小动物的类型,C
表示兔子(coney),R
表示老鼠(rat),F
表示青蛙(frog))。
请你参照输出样例,输出所用动物总数,每种动物的数量,以及每种动物所占百分比。
注意输出百分比时,保留两位小数。
1≤N≤100
1≤A≤15
10
10 C
6 R
15 F
5 C
14 R
9 C
6 R
8 F
5 C
14 R
Total: 92 animals
Total coneys: 29
Total rats: 40
Total frogs: 23
Percentage of coneys: 31.52 %
Percentage of rats: 43.48 %
Percentage of frogs: 25.00 %
#include
#include
#include
using namespace std;
int main()
{
int n;
cin >> n;
int m;
char t;
int c=0,r=0,f=0,sum=0;
double s1,s2,s3;
for(int i=0;i> m>>t;
switch(t)
{
case 'C':
c=c+m;
break;
case 'R':
r=r+m;
break;
case 'F':
f=f+m;
break;
}
sum=sum+m;
}
s1=(double)c/(double)sum*100;
s2=(double)r/(double)sum*100;
s3=(double)f/(double)sum*100;
cout << "Total: "<
输入 N 对整数对 X,Y,对于每对 X,Y,请你求出它们之间(不包括 X 和 Y)的所有奇数的和。
第一行输入整数 N,表示共有 N 对测试数据。
接下来 N 行,每行输入一组整数 X 和 Y。
每对 X,Y 输出一个占一行的奇数和。
1≤N≤100
−1000≤X,Y≤1000
7
4 5
13 10
6 4
3 3
3 5
3 4
3 8
0
11
5
0
0
0
12
#include
#include
#include
using namespace std;
int main()
{
int n;
cin >> n;
int sum=0;
for (int i = 0; i < n; i ++ )
{
int a,b;
cin >> a >> b;
if(a>b){
b=a;
int t=b;
a=t;
}
for ( int j=a+1; j < b; j ++ )
{
if(abs(j)%2==1)
{
sum=sum+j;
}
}
cout <
输入若干个整数对 M,N,对于每个数对,输出以这两个数为最大值和最小值的公差为 11 的等差数列。
注意,当输入整数对中,任意一个数为 00 或负整数时,立即停止输入,且该组数对无需作任何处理。
输入共若干行,每行包含两个整数。
最后一行的两个整数中,至少有一个是非正整数。
对于每组需作处理的数对,输出一个结果,每个结果占一行。
结果包含从最小值到最大值的数字序列以及数字序列各数字之和。
具体格式请参照输出样例。
M,N≤100
2 5
6 3
5 0
2 3 4 5 Sum=14
3 4 5 6 Sum=18
#include
#include
#include
using namespace std;
int main()
{
int n=10000;
for (int i = 0; i < n; i ++ )
{
int x,y;
int sum=0;
cin >> x>>y;
if(x<=0||y<=0)
break;
if(x>y)
swap(x,y);
int t=y-x;
for (int i = 0; i <=t; i ++ )
{
sum=sum+x;
cout << x++<<" ";
}
cout <<"Sum="<
一个整数,除了本身以外的其他所有约数的和如果等于该数,那么我们就称这个整数为完全数。
例如,66就是一个完全数,因为它的除了本身以外的其他约数的和为 1+2+3=6。
现在,给定你 N个整数,请你依次判断这些数是否是完全数。
第一行包含整数 N,表示共有 N 个测试用例。
接下来 N 行,每行包含一个需要你进行判断的整数 X。
每个测试用例输出一个结果,每个结果占一行。
如果测试数据是完全数,则输出 X is perfect
,其中 X 是测试数据。
如果测试数据不是完全数,则输出 X is not perfect
,其中 X 是测试数据。
1≤N≤100
1≤X≤10^8
3
6
5
28
6 is perfect
5 is not perfect
28 is perfect
#include
#include
#include
#include
using namespace std;
int main()
{
int n;
cin >> n;
for (int i = 0; i < n; i ++ )
{
int ans=0;
int a;
cin >> a;
for (int i = 1; i <=sqrt(a); i ++ )//暴力优化,举例6,2是6的约数,那么6/2=3也是
{
if(a%i==0)
{
ans+=i;
if(i!=a/i)
ans=ans+a/i;
}
}
ans=ans-a;//在i=1 != 6/1时加上了6本身
if (ans==a&&a!=1)
{
cout << a<<" is perfect"<
使用曼哈顿距离公式打印菱形_c++曼哈顿距离棱形-CSDN博客
输入一个奇数 n,输出一个由 *
构成的 n 阶实心菱形。
一个奇数 n。
输出一个由 *
构成的 n 阶实心菱形。
具体格式参照输出样例。
1≤n≤99
5
*
***
*****
***
*
#include
#include
using namespace std;
int main()
{
int n;
cin >> n;
int x=n/2;
int y=n/2;
for (int i = 0; i < n; i ++ )
{
for (int j = 0; j < n; j ++ ){
if(abs(i-x)+abs(j-y)<=n/2)
cout << "*";
else
cout << " ";
}
cout << endl;
}
return 0;
}
i+j<11
i 输入整数 N,输出一个 N阶的回字形二维数组。 数组的最外层为 1,次外层为 2,以此类推。 输入包含多行,每行包含一个整数 N。 当输入行为 N=0 时,表示输入结束,且该行无需作任何处理。 对于每个输入整数 N,输出一个满足要求的 N 阶二维数组。 每个数组占 N 行,每行包含 N个用空格隔开的整数。 每个数组输出完毕后,输出一个空行。 0≤N≤100 输入整数 N,输出一个 N阶的二维数组。 数组的形式参照样例。 输入包含多行,每行包含一个整数 N。 当输入行为 N=0 时,表示输入结束,且该行无需作任何处理。 对于每个输入整数 N,输出一个满足要求的 N 阶二维数组。 每个数组占 N 行,每行包含 N个用空格隔开的整数。 每个数组输出完毕后,输出一个空行。 0≤N≤100 输入一个整数 N和一个长度为 N 的整数数组 X。 请你找到数组中最小的元素,并输出它的值和下标。 注意,如果有多个最小值,则返回下标最小的那个。 第一行包含整数 N。 第二行包含 N 个用空格隔开的整数 X[i]。 第一行输出 第二行输出 1 输入两个整数 n 和 m,输出一个 n 行 m 列的矩阵,将数字 1到 n×m 按照回字蛇形填充至矩阵中。 具体矩阵形式可参考样例。 输入共一行,包含两个整数 n 和 m。 输出满足要求的矩阵。 矩阵占 n行,每行包含 m 个空格隔开的整数。 1≤n,m≤100 输入一个 n,再输入 n个整数。将这个数组顺时针旋转 k(k≤n)次,最后将结果输出。旋转一次是指:将最左边的数放到最右边。 给你一个只包含小写字母的字符串。 请你判断是否存在只在字符串中出现过一次的字符。 如果存在,则输出满足条件的字符中位置最靠前的那个。 如果没有,输出 共一行,包含一个由小写字母构成的字符串。 数据保证字符串的长度不超过 100000。 输出满足条件的第一个字符。 如果没有,则输出 有两个不包含空白字符的字符串 str 和 substr,str的字符个数不超过 10,substr 的字符个数为 3。(字符个数不包括字符串结尾处的 将 substr 插入到 str中 ASCII 码最大的那个字符后面,若有多个最大则只考虑第一个。 输入包括若干行,每一行为一组测试数据,格式为 对于每一组测试数据,输出插入之后的字符串。 输入一个字符串,字符串中可能包含多个连续的空格,请将多余的空格去掉,只留下一个空格。 共一行,包含一个字符串。 输出去掉多余空格后的字符串,占一行。 输入字符串的长度不超过 200。 在传输信息的过程中,为了保证信息的安全,我们需要对原信息进行加密处理,形成加密信息,从而使得信息内容不会被监听者窃取。 现在给定一个字符串,对其进行加密处理。 加密的规则如下: 请你输出加密后的字符串。 共一行,包含一个字符串。注意字符串中可能包含空格。 输出加密后的字符串。 输入字符串的长度不超过 100。 求一个字符串中最长的连续出现的字符,输出该字符及其出现次数,字符串中无空白字符(空格、回车和 tab),如果这样的字符不止一个,则输出第一个。 第一行输入整数 N,表示测试数据的组数。 每组数据占一行,包含一个不含空白字符的字符串,字符串长度不超过 200。 共一行,输出最长的连续出现的字符及其出现次数,中间用空格隔开。 一个以 输入一行字符串,表示这个简单英文句子,长度不超过 500。 该句子中最长的单词。如果多于一个,则输出第一个。 双指针算法: 利用输入字符串的特性,但是要注意以 编写程序,读入一行英文(只包含字母和空格,单词间以单个空格分隔),将所有单词的顺序倒排并输出,依然以单个空格分隔。 输入为一个字符串(字符串长度至多为 100)。 输出为按要求排序后的字符串。 对于一个字符串来说,定义一次循环移位操作为:将字符串的第一个字符移动到末尾形成新的字符串。 给定两个字符串 s1 和 s2,要求判定其中一个字符串是否是另一字符串通过若干次循环移位后的新字符串的子串。 例如 共一行,包含两个字符串,中间由单个空格隔开。 字符串只包含字母和数字,长度不超过 30。 如果一个字符串是另一字符串通过若干次循环移位产生的新串的子串,则输出 k < j; k++) { } 编写程序,读入一行英文(只包含字母和空格,单词间以单个空格分隔),将所有单词的顺序倒排并输出,依然以单个空格分隔。 输入为一个字符串(字符串长度至多为 100)。 输出为按要求排序后的字符串。 对于一个字符串来说,定义一次循环移位操作为:将字符串的第一个字符移动到末尾形成新的字符串。 给定两个字符串 s1 和 s2,要求判定其中一个字符串是否是另一字符串通过若干次循环移位后的新字符串的子串。 例如 共一行,包含两个字符串,中间由单个空格隔开。 字符串只包含字母和数字,长度不超过 30。 如果一个字符串是另一字符串通过若干次循环移位产生的新串的子串,则输出 [外链图片转存中…(img-8iskIOae-1704782512596)]12.平方矩阵Ⅰ
题目
输入格式
输出格式
数据范围
输入样例:
1
2
3
4
5
0
输出样例:
1
1 1
1 1
1 1 1
1 2 1
1 1 1
1 1 1 1
1 2 2 1
1 2 2 1
1 1 1 1
1 1 1 1 1
1 2 2 2 1
1 2 3 2 1
1 2 2 2 1
1 1 1 1 1
题解:
#include
13.平方矩阵Ⅱ
题目:
输入格式
输出格式
数据范围
输入样例:
1
2
3
4
5
0
输出样例:
1
1 2
2 1
1 2 3
2 1 2
3 2 1
1 2 3 4
2 1 2 3
3 2 1 2
4 3 2 1
1 2 3 4 5
2 1 2 3 4
3 2 1 2 3
4 3 2 1 2
5 4 3 2 1
题解:
#include
14.找数字
题目:
输入格式
输出格式
Minimum value: x
,其中 x 为数组元素最小值。Position: y
,其中 y为最小值元素的下标(下标从 00 开始计数)。数据范围
输入样例:
10
1 2 3 4 -5 6 7 8 9 10
输出样例:
Minimum value: -5
Position: 4
题解:
#include
15.蛇形矩阵
题目:
输入格式
输出格式
数据范围
输入样例:
3 3
输出样例:
1 2 3
8 9 4
7 6 5
题解:
#include
16.旋转数组
题目:
17.只出现一次的字符
题目:
no
。输入格式
输出格式
no
。输入样例:
abceabcd
输出样例:
e
题解:
#include
18.字符串插入
题目:
\0
。)输入格式
str substr
输出格式
输入样例:
abcab eee
12343 555
输出样例:
abceeeab
12345553
题解:
#include
19.去掉多余空格(双指针算法)
题目:
输入格式
输出格式
数据范围
保证输入字符串的开头和结尾没有空格。输入样例:
Hello world.This is c language.
输出样例:
Hello world.This is c language.
题解:
#include
20.信息加密
题目:
输入格式
输出格式
数据范围
输入样例:
Hello! How are you!
输出样例:
Ifmmp! Ipx bsf zpv!
题解:
#include
21.字符串中最长的连续出现的字符(双指针)
题目:
输入格式
输出格式
输入样例:
2
aaaaabbbbbcccccccdddddddddd
abcdefghigk
输出样例:
d 10
a 1
题解:
#include
22.最长单词(双指针算法)
题目:
.
结尾的简单英文句子,单词之间用单个空格分隔,没有缩写形式和其它特殊形式,求句子中的最长单词。输入格式
输出格式
输入样例:
I am a student of Peking University.
输出样例:
University
题解1:
#include
题解2:
.
结尾#include
23.倒排单词
题目:
输入格式
输出格式
输入样例:
I am a student
输出样例:
student a am I
题解1:
#include
题解2:
//创建一个字符数组
#include
24.字符串移位包含问题(未解决)
题目:
CDAA
是由 AABCD
两次移位后产生的新串 BCDAA
的子串,而 ABCD
与 ACBD
则不能通过多次移位来得到其中一个字符串是新串的子串。输入格式
输出格式
true
,否则输出 false
。输入样例:
AABCD CDAA
输出样例:
true
题解:
25.有时间再看
b = b + a[k];
}
} i = j;
}
cout << b << endl;
return 0;
### 题解2:
利用输入字符串的特性,但是要注意以 `.`结尾
```c++
#include
23.倒排单词
题目:
输入格式
输出格式
输入样例:
I am a student
输出样例:
student a am I
题解1:
#include
题解2:
//创建一个字符数组
#include
24.字符串移位包含问题(未解决)
题目:
CDAA
是由 AABCD
两次移位后产生的新串 BCDAA
的子串,而 ABCD
与 ACBD
则不能通过多次移位来得到其中一个字符串是新串的子串。输入格式
输出格式
true
,否则输出 false
。输入样例:
AABCD CDAA
输出样例:
true
题解:
25.有时间再看