文章目录
前言
openjudge基础练习题以及一点点小步骤
一、A+B Problem
1.题目
描述
Calculate a + b
输入
Two integer a,b (0 ≤ a,b ≤ 10)
输出
Output a + b
样例输入
1 2
样例输出
3
2. 代码
#include<iostream>
using namespace std;
int main()
{
int a, b;
cin>>a>>b;
cout<<a+b<<endl;
return 0;
}
二、计算书费
1.题目
描述
下面是一个图书的单价表:
计算概论 28.9 元/本
数据结构与算法 32.7 元/本
数字逻辑 45.6元/本
C++程序设计教程 78 元/本
人工智能 35 元/本
计算机体系结构 86.2 元/本
编译原理 27.8元/本
操作系统 43 元/本
计算机网络 56 元/本
JAVA程序设计 65 元/本
给定每种图书购买的数量,编程计算应付的总费用。
输入
输入第一行包含一个正整数k(0<k<100),表示有k组测试数据;接下来k行,每行包含一组测试数据。每组测试数据包含10个整数(大于等于0,小于等于100),分别表示购买的《计算概论》、《数据结构与算法》、《数字逻辑》、《C++程序设计教程》、《人工智能》、《计算机体系结构》、《编译原理》、《操作系统》、《计算机网络》、《JAVA程序设计》的数量(以本为单位)。每两个整数用一个空格分开。
输出
对于每组测试数据,输出一行。该行包含一个浮点数f,表示应付的总费用。精确到小数点后两位。
可用printf(“%.2f\n”, sum)来输出sum的值,并精确到小数点后两位。
样例输入
2
1 5 8 10 5 1 1 2 3 4
3 5 6 3 100 1 1 0 1 0
样例输出
2140.20
4427.80
2.代码
#include<stdio.h>
int main()
{
int k,n,count=0;
double s[k];
double price[]= {28.9, 32.7, 45.6, 78.0, 35.0, 86.2, 27.8, 43.0, 56.0, 65.0};
scanf("%d",&k);
while(count<k) {
for(int i=0; i<10; i++) {
scanf("%d", &n);
s[count]+=price[i]*n;
}
count++;
}
for(int j=0; j<k; j++) {
printf("%.2f\n",s[j]);
}
return 0;
}
三、整数的个数
1.题目
描述
给定k(1
< k < 100)个正整数,其中每个数都是大于等于1,小于等于10的数。写程序计算给定的k个正整数中,1,5和10出现的次数。
输入
输入有两行:第一行包含一个正整数k,第二行包含k个正整数,每两个正整数用一个空格分开。
输出
输出有三行,第一行为1出现的次数,,第二行为5出现的次数,第三行为10出现的次数。
样例输入
5
1 5 8 10 5
样例输出
1
2
1
2.代码
#include<iostream>
using namespace std;
int main()
{
int k;
cin>>k;
int a=0,b=0,c=0;
for(int i=0; i<k; i++)
{
int n;
cin>>n;
if(n==1)
{
a++;
}
else if(n==5)
{
b++;
}
else if(n==10)
{
c++;
}
}
cout<<a<<"\n"<<b<<"\n"<<c;
return 0;
}
四、整数的立方和
1.题目
描述
给定一个正整数k(1<k<10),求1到k的立方和m。即m=1+222+…+kkk。
输入
输入只有一行,该行包含一个正整数k。
输出
输出只有一行,该行包含1到k的立方和。
样例输入
5
样例输出
225
2.代码
#include <iostream>
#include <cmath>
using namespace std;
int main()
{
int i,n;
double sum=0;
cin>>n;
for(i=1;i<=n;i++)
{
sum+=pow(i,3);//求立方用pow,平方用a*a,平方根用sqrt
}
cout<<sum;
return 0;
}
五、化验诊断
1.题目
描述
下表是进行血常规检验的正常值参考范围,及化验值异常的临床意义:
给定一张化验单,判断其所有指标是否正常,如果不正常,统计有几项不正常。化验单上的值必须严格落在正常参考值范围内,才算是正常。正常参考值范围包括边界,即落在边界上也算正常。
输入
输出
对于每组测试数据,输出一行。如果所有检验项目正常,则输出:normal;否则输出不正常的项的数目。
样例输入
2
female 4.5 4.0 115 37 200
male 3.9 3.5 155 36 301
样例输出
normal
3
2.代码
#include<iostream>
#include<cstring>
#include<string>
using namespace std;
int main()
{
int i, j;
int k;
string gender;
double a1, a2, a3, a4, a5;
int num = 0;
cin >> k;
for (i = 0; i < k; i++)
{
cin >> gender >> a1 >> a2 >> a3 >> a4 >> a5;
if (a1 < 4.0 || a1 >10.0)
num++;
if (a2 < 3.5 || a2 > 5.5)
num++;
if (gender == "male" )
{
if (a3 < 120 || a3 > 160)
num++;
if (a4 < 42 || a4 > 48)
num++;
}
else if (gender == "female" )
{
if (a3 < 110 || a3 > 150)
num++;
if (a4 < 36 || a4 > 40)
num++;
}
if (a5 < 100 || a5 > 300)
num++;
if (num == 0)
cout << "normal" << endl;
else
cout << num << endl;
num = 0;
}
return 0;
}
六、求分数序列和
1.题目
描述
有一个分数序列 2/1,3/2,5/3,8/5,13/8,21/13,… 求这个分数序列的前n项之和。
输入
输入有一行:正整数n。
输出
输出有一行:分数序列的和(浮点数,精确到小数点后4位)。
可以printf(“%.4lf\n”, a)输出浮点数并精确到小数点后4位。
样例输入
99
样例输出
160.4849
2.代码
#include<iostream>
int main(){
int n;
double sum=0;
int i;
double a=2.0,b=1.0,c=0;
cin>>n;
for(i=1;i<=n;i++){
sum=sum+a/b;
c=a;
a=a+b;
b=c;
}
cout<<fixed<<setprecision(4)<<num<<endl;
}
七、求阶数的和
1.题目
描述
给定正整数n,求不大于n的正整数的阶乘的和(即求1!+2!+3!+…+n!)
输入
输入有一行,包含一个正整数n(1 < n < 12)。
输出
输出有一行:阶乘的和。
样例输入
5
样例输出
153
2.代码
#include <iostream>
using namespace std;
int main()
{
int n;
cin>>n;
int sum = 0;
for (int i=1; i<=n; ++i)
{
int x = 1;
for (int j=1; j<=i; ++j)
x *=j;
sum+=x;
}
cout<<sum<<endl;
return 0;
}
八、打印完数
1.题目
描述
一个数如果恰好等于它的因子之和,这个数就成为“完数”。例如,6的因子为1、2、3,而6=1+2+3,因此6是“完数”。编程序打印出1000之内(包括1000)所有的完数,并按如下格式输出其所有因子:
6 its factors are 1,2,3
输入
无输入
输出
输出1000以内所有的完数及其因子,每行一个完数。
样例输入
样例输出
2.代码
#include <iostream>
using namespace std;
int main()
{
int i, j, sum = 0;
for (i = 1; i <= 1000; i++) {
sum = 0;
for (j = 1; j < i; j++) {
if ((i % j) == 0) {
sum += j;
}
}
if (sum == i) {
cout << i << " " << "its factors are ";
cout << "1";
for (j = 2; j < i; j++) {
if ((i % j) == 0) {
cout << "," << j;
}
}
cout << endl;
}
}
return 0;
}
九、数组逆序重放
1.题目
描述
将一个数组中的值按逆序重新存放。例如,原来的顺序为8,6,5,4,1。要求改为1,4,5,6,8。
输入
输入为两行:第一行数组中元素的个数n(1<n<100),第二行是n个整数,每两个整数之间用空格分隔。
输出
输出为一行:输出逆序后数组的整数,每两个整数之间用空格分隔。
样例输入
5
8 6 5 4 1
样例输出
1 4 5 6 8
2.代码
#include <iostream>
#include <cmath>
using namespace std;
int main()
{
int n;
int a[100];
cin>>n;
for(int i=0;i<n;i++){
cin>>a[i];
}
for(int j=n-1;j>=0;j--)
{
cout<<a[j]<<" ";
}
return 0;
}
十、与7无关的数
1.题目
描述
一个正整数,如果它能被7整除,或者它的十进制表示法中某一位上的数字为7,则称其为与7相关的数.现求所有小于等于n(n < 100)的与7无关的正整数的平方和.
输入
输入为一行,正整数n(n < 100)
输出
输出一行,包含一个整数,即小于等于n的所有与7无关的正整数的平方和。
样例输入
21
样例输出
2336
2.代码
#include <iostream>
using namespace std;
int main()
{
int n,sum=0;
cin>>n;
if(n>=100) return 0;
for(int i=0; i<=n; i++)
{
if(i%7!=0 && i%10!=7 && i/10!=7)
sum+=i*i;
}
cout<<sum;
return 0;
}