A+B+C问题、 整除问题、判断质数、 简单斐波那契、矩阵翻转

今天是第一天,每次一隔好久,就会打起头文件都要犹豫,-_-||

这是一个非常简单的题目,意在考察你编程的基础能力。千万别想难了哦。输入为一行,包括了用空格分隔的三个整数 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 组测试数据,共 5if(i==n-1 && n%i!=0)
    printf("YES");
这一步有问题,当n为6,i=56%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条件的是没有结果,不知道原因。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,以下是蓝桥杯斐波数列整除问题的C语言代码: ```c #include <stdio.h> int main() { int n; scanf("%d", &n); int fib[100005]; fib[1] = 1; fib[2] = 1; for (int i = 3; i <= n; i++) { fib[i] = (fib[i-1] + fib[i-2]) % 10007; } printf("%d\n", fib[n]); return 0; } ``` 这个程序可以计算斐波数列的第n项,并对10007取模。在计算过程中,我们只需要保留每一项对10007取模后的结果,可以节省空间并避免溢出的问题。 ### 回答2: 斐波数列是指每个数都是前两个数之和的数列,例如:0、1、1、2、3、5、8、13、21、34、……。 蓝桥杯中的斐波数列整除问题是给定一个整数n,要求计算出斐波数列中第一个大于n的数,且这个数可以整除给定的整数m。 要解决这个问题,我们可以使用循环来逐个计算斐波数列的数,并判断是否满足条件。具体的C语言代码如下: ```c #include <stdio.h> int main() { int n, m; printf("请输入n和m的值:"); scanf("%d%d", &n, &m); int fib1 = 0; // 斐波数列的第一个数 int fib2 = 1; // 斐波数列的第二个数 int fib = fib1 + fib2; // 斐波数列的当前数 while (fib <= n || fib % m != 0) { fib1 = fib2; fib2 = fib; fib = fib1 + fib2; } printf("第一个大于%d且可以整除%d的斐波数是:%d\n", n, m, fib); return 0; } ``` 以上代码中,我们使用三个变量来记录斐波数列的前两个数和当前数。使用循环来计算下一个数直到满足条件为止。最后输出结果即为第一个大于n且可以整除m的斐波数。 这是一种基本的解决方法,但可能在n和m较大时会执行时间较长。可以使用一些优化技巧,如使用矩阵快速幂的方法来加速计算过程。 ### 回答3: 题目要求编写C语言程序,判断一个斐波数列中的某个数能否被给定的整数整除。 首先,我们需要了解斐波数列的定义,即第n个数是由前两个数相加得到的,其中前两个数分别是0和1。根据这个定义,我们可以使用循环来生成斐波数列,直到生成的数大于给定的整数。 接下来,我们遍历生成的斐波数列,判断其中的每个数是否能够被给定的整数整除。如果是,则输出该数能被整除,如果不是,则继续遍历下一个数。 以下是一个简单的C语言程序示例: #include <stdio.h> int main() { int n, i, a, b, c, num; printf("请输入给定的整数:"); scanf("%d", &n); a = 0; // 第一个数 b = 1; // 第二个数 c = a + b; // 第三个数 while (c <= n) { if (c % n == 0) { printf("%d 能被 %d 整除\n", c, n); } a = b; b = c; c = a + b; } return 0; } 在上述程序中,我们使用了一个while循环来生成斐波数列,并使用if语句判断每个数是否能被给定的整数n整除。如果能整除,则输出结果。 以上是一个用C语言解决蓝桥杯斐波数列整除问题的思路和示例代码。需要注意的是,该程序只输出能够被整除的数,如果需要输出整个斐波数列,可以在每次循环时增加一个输出语句。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值