今天是第一天,每次一隔好久,就会打起头文件都要犹豫,-_-||
这是一个非常简单的题目,意在考察你编程的基础能力。千万别想难了哦。输入为一行,包括了用空格分隔的三个整数 A、B、C(数据范围均在−40 ~ 40 之间)。输出为一行,为“A+B+CA+B+CA+B+C”的计算结果。
样例输入
22 1 3样例输出
26
#include<stdio.h>
int main(){
int A,B,C,s=0;
scanf("%d %d %d",&A,&B,&C);
s = A+B+C;
printf("%d",s);
}
判断一个数是否能被另一个整数整除是一个挺简单的问题,一般一个模运算就可以搞定了,懒惰的晓萌还是不想自己做,于是找到你帮他写代码,你就帮帮他吧
输入格式
输入包括两个由空格分开的整数M和N(1≤M,N≤500)输出格式
输出包括一行,如果MMM可以被NNN整除就输出YES,否则输出NO(结果大小写敏感)。样例输入
21 7样例输出
YES
模运算,“%”运算符,求余数
#include<stdio.h>
int main(){
int m,n;
scanf("%d %d",&m,&n);
int a = m % n;
if(a == 0)
printf("YES");
else
printf("NO");
}
看到别人做的题,很细心啊,考虑到这个,而且根据题目要求加了
如果-3%2是等于1还是-1呢?在C99中为整数除法规定”趋零截尾”规则:如果第一个操作数为负数,那么得到的模也是负数;如果为正,则为正数。
if(m < 1 || m > 500 || n < 1 || n > 500)
对于大于1的数,如果除了1和它本身,它不能再被其它正整数整除,那么我们说它是一个质数。晓萌想判断一个数是不是质数,希望找你写个程序,帮助她进行判断。
输入格式
输入包括一行,为一个整数 N(1<N ≤ 1000),正是晓萌给出你让你判断的数字。输出格式
输出包括一行,如果晓萌给出的整数N为质数,那么输出YES;如果N不是质数,那么输出NO。样例输入
3样例输出
YES
#include<stdio.h>
int main(){
int n,i;
scanf("%d",&n);
if(n<=1 || n>1000)
return 0;
for(i=2; i<n; i++){
if(n%i == 0)
printf("NO");
if(i==n-1 && n%i!=0)
printf("YES");
}
return 0;
}
已通过 2 组测试数据,共 5 组
if(i==n-1 && n%i!=0)
printf("YES");
这一步有问题,当n为6,i=5,6%5=1,但6不是质数,加了个break,保证这个数错误的时候立即跳出循环。
#include<stdio.h>
int main(){
int n,i;
scanf("%d",&n);
if(n<=1 || n>1000)
return 0;
for(i=2; i<n; i++){
if(n%i == 0){
printf("NO");
break;
}
if(i==n-1 && n%i!=0)
printf("YES");
}
return 0;
}
斐波那契数列是一种非常有意思的数列,由 0 和 1 开始,之后的斐波那契系数就由之前的两数相加。用数学公式定义斐波那契数列则可以看成如下形式:
F0=0F_0=0F 0 =0
F1=1F_1=1F 1 =1
Fn=Fn−1+Fn−2F_n=F_{n-1}+F_{n-2}F n =F n−1 +F n−2
我们约定 FnF_nF n 表示斐波那契数列的第 nnn 项,你能知道斐波那契数列中的任何一项吗?输入格式
输入包括一行,包括一个整数 N(0≤N≤50)。输出格式
输出包括一行,包括一个整数,为斐波那契数列的第 N 项的值。样例输入
7样例输出
13
#include<stdio.h>
int main(){
int n,i;
int a[50]={0};
a[0]=0,a[1]=1;
scanf("%d",&n);
if(n<0 || n>50)
return 0;
for(i=2; i<50; i++){
a[i] = a[i-1] + a [i-2];
}
printf("%d",a[n]);
return 0;
}
晓萌最近在做一个翻转图片的应用,你可能也知道,图片其实是由一个个的点组成的。于是,晓萌想先做一个可以翻转矩阵的程序,来解决他问题的核心部分。
输入格式
输入第一行包括由空格分开的整数M、N、T(0 < M < 200,0 < N < 200,T=0或1),其中M和N分别表示待处理矩阵的行数与列数,T为0时表示左右翻转,为1时表示上下翻转。
之后的M行,每行包括由空格分隔的N个整数,依次为输入矩阵的每一行的数据。输出格式
输出包括 M行 N 列,每个数字之间用一个空格分隔,每一行行末均有一个空格,表示的是按照要求翻转后的矩阵。样例输入
4 4 1
1 2 3 4
5 6 7 8
9 0 1 2
3 4 5 6样例输出
3 4 5 6
9 0 1 2
5 6 7 8
1 2 3 4
#include <stdio.h>
int main(){
int m,n,t,temp=0;
scanf("%d %d %d",&m,&n,&t);
int a[m][n],i,j;
for(i=0; i<m; i++){
for(j=0; j<n; j++)
scanf("%d ",&a[i][j]);
}
if(t == 0){
for(i=0;i<m;i++){
for(j=0;j<(n/2);j++){
temp = a[i][j];
a[i][j] = a[i][n-1-j];
a[i][n-1-j] = temp;
}
}
}
else if(t == 1){
for(i=0;i<(m/2);i++){
for(j=0;j<n;j++){
temp = a[i][j];
a[i][j] = a[m-1-i][j];
a[m-1-i][j] = temp;
}
}
}
for(i=0; i<m; i++){
for(j=0; j<n; j++)
printf("%d ",a[i][j]);
printf("\n");
}
return 0;
}
很奇怪的是加了0 < M < 200,0 < N < 200,T=0或1条件的是没有结果,不知道原因。