算法竞赛入门【码蹄集新手村600题】(MT1220-1240)C语言(一)

简介: 算法竞赛入门【码蹄集新手村600题】(MT1220-1240)C语言

码蹄集网站地址:https://www.matiji.net/exam/ojquestionlist


目录

MT1221 分数的总和

(1)题目


格式


         

样例1


         

(2)参考代码

#include<stdio.h>
#define N 20
int main() 
{
    double a[N], b[N], sum = 0;
    int i;
    a[0] = 1.0;
    a[1] = 2.0;
    b[0] = 2.0;
    b[1] = 3.0;
    for (i=2;i<N;i++)
    {
        a[i] = a[i-1] + a[i-2];
        b[i] = b[i-1] + b[i-2];
    }
    //校验数据
    // for (i=0;i<N;i++)
    // {
    //     printf("%lf %lf\n", a[i], b[i]);
    // }
    for (i=0;i<N;i++)
    {
        sum = sum + (b[i] / a[i]);
    }
    printf("%.2lf", sum);
}

MT1222 等差数列

(1)题目

求等差数列前N项的级数之和。不考虑不合理的输入等特殊情况。


格式

输入格式:
输入N,首项M,差值K,整型,空格分隔。
输出格式:
输出整型

样例1

输入:
5 1 3
输出:
35

(2)参考代码

#include<stdio.h>
int main() 
{ 
    int N, M, K;
    scanf("%d %d %d", &N, &M, &K);
    printf("%d\n", M * N + N * (N - 1) * K / 2);
    return 0; 
}

MT1223 N是什么

(1)题目

给定一系列数字3、10、21、36…,输入正整数N,输出上述序列的第N个值。从N=1开始计数。


格式

输入格式:
输入正整数N
输出格式:
输出整型

样例1

输入:
5
输出:
55

备注

N小于10000

(2)参考代码

#include<stdio.h>
int main()
{
    int N, num, i = 3;
    scanf("%d", &N);
    num = N * (i + 2 * (N - 1));
    printf("%d\n", num);
}

MT1224 棋盘

(1)题目

求一个N*N棋盘中的方块总数。


格式

输入格式:
输入整型N    
输出格式:
输出整型

样例1

输入:
2
输出:
5

备注

考虑到取值范围,可用long整型定义变量

(2)参考代码

#include<stdio.h>
int main() 
{
    int N;
    long count = 0;
    scanf("%d", &N);
    for (int i = 1;i<=N;i++)
    {
        count += (i * i);
    }
    printf("%ld", count);
    return 0; 
}

MT1225 复杂分数

(1)题目

编写程序连续输入a1、a2、…、a5,计算下列表达式的值并输出。本题不考虑输入0,负数或者其他特殊情况。


格式

输入格式: 
输入整型,空格分隔。
输出格式: 
输出为实型

样例1

输入格式: 
1 2 3 4 5
输出格式: 
1.571429

(2)参考代码

#include<stdio.h>
int main() 
{ 
    double a[5];
    for (int i=0;i<5;i++)
    {
        scanf("%lf", &a[i]);
    }
    double num = a[4];
    for (int i=3;i>=0;i--)
    {
        num = 1 + a[i] / num;
    }
    printf("%lf", num);
    return 0; 
}

MT1226 解不等式

(1)题目

n为正整数,求解n满足不等式:


格式

输入格式:
输入正整数a,b,空格分隔。
输出格式:
输出整型区间上下限,空格分隔。

样例1

输入:
2010 2011
输出:
18611 18621

备注

对于100%的数据:1<=n<=100,000,1<=a<b

(2)参考代码

#include<stdio.h>
int main() 
{ 
    int a, b, n1, n2;
    scanf("%d %d", &a, &b);
    double sum = 0, num = 0;
    for (int i=1;;i++)
    {
        num += (1.0 / (double)i);
        sum += 1.0 / num;
        if (a < sum)
        {
            n1 = i;
            break;
        }
    }
    for (int i=n1+1;;i++)
    {
        num += (1.0 / (double)i);
        sum += 1.0 / num;
        if (b <= sum)
        {
            n2 = i - 1;
            break;
        }
    }
    printf("%d %d", n1, n2);
    return 0; 
}

MT1227 宝宝爬楼梯

(1)题目

楼梯有N个台阶(N<=10),宝宝想爬到顶部。她一次可以爬1级或2级台阶。统计宝宝可以用多少种方式爬到达顶端。


格式

输入格式: 
输入正整数N
输出格式: 
输出整型

样例1

输入格式: 
4
输出格式: 
5

(2)参考代码

#include<stdio.h>
int main() 
{ 
    int a[10] = {0, 1, 2};
    int N;
    scanf("%d", &N);
    for (int i=3;i<=N;i++)
    {
        a[i] = a[i-1] + a[i-2];
    }
    printf("%d\n", a[N]);
    return 0; 
}

MT1228 宝宝抢糖果

(1)题目

宝宝们一起抢N个糖果(N<=10),手快的宝宝可以抢到2个糖果,手慢的只能抢到一个糖果。统计糖果可以多少种方式被瓜分。


格式

输入格式:
输入正整数N
输出格式:
输出整型

样例1

输入:
4
输出:
5

(2)参考代码


         


目录
相关文章
|
14天前
|
机器学习/深度学习 人工智能 算法
深度学习入门:理解神经网络与反向传播算法
【9月更文挑战第20天】本文将深入浅出地介绍深度学习中的基石—神经网络,以及背后的魔法—反向传播算法。我们将通过直观的例子和简单的数学公式,带你领略这一技术的魅力。无论你是编程新手,还是有一定基础的开发者,这篇文章都将为你打开深度学习的大门,让你对神经网络的工作原理有一个清晰的认识。
|
2月前
|
存储 算法 C语言
"揭秘C语言中的王者之树——红黑树:一场数据结构与算法的华丽舞蹈,让你的程序效率飙升,直击性能巅峰!"
【8月更文挑战第20天】红黑树是自平衡二叉查找树,通过旋转和重着色保持平衡,确保高效执行插入、删除和查找操作,时间复杂度为O(log n)。本文介绍红黑树的基本属性、存储结构及其C语言实现。红黑树遵循五项基本规则以保持平衡状态。在C语言中,节点包含数据、颜色、父节点和子节点指针。文章提供了一个示例代码框架,用于创建节点、插入节点并执行必要的修复操作以维护红黑树的特性。
68 1
|
2月前
|
C语言
C语言------程设设计入门
这篇文章是C语言程序设计的入门教程,涵盖了C程序的实现过程、VC集成开发环境的使用、基本数据类型的使用、格式控制字符的作用,以及通过示例代码演示了如何使用printf()函数输出不同类型的数据。
C语言------程设设计入门
|
2月前
|
机器学习/深度学习 人工智能 算法
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
本文全面介绍了人工智能(AI)的基础知识、操作教程、算法实现及其在实际项目中的应用。首先,从AI的概念出发,解释了AI如何使机器具备学习、思考、决策和交流的能力,并列举了日常生活中的常见应用场景,如手机助手、推荐系统、自动驾驶等。接着,详细介绍了AI在提高效率、增强用户体验、促进技术创新和解决复杂问题等方面的显著作用,同时展望了AI的未来发展趋势,包括自我学习能力的提升、人机协作的增强、伦理法规的完善以及行业垂直化应用的拓展等...
160 3
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
|
2月前
|
NoSQL Java 编译器
C语言从入门到精通该怎样学?
持续学习与实践:编程是一门需要不断学习和实践的技能,要保持对新技术和新知识的敏感性,并持续进行编程实践。
40 1
|
3月前
|
存储 Java C语言
【C语言入门】初识C语言:掌握编程的基石
【C语言入门】初识C语言:掌握编程的基石
56 4
【C语言入门】初识C语言:掌握编程的基石
|
3月前
|
机器学习/深度学习 数据采集 人工智能
机器学习算法入门与实践
【7月更文挑战第22天】机器学习算法入门与实践是一个既充满挑战又极具吸引力的过程。通过掌握基础知识、理解常见算法、注重数据预处理和模型选择、持续学习新技术和参与实践项目,你可以逐步提高自己的机器学习技能,并在实际应用中取得优异的成绩。记住,机器学习是一个不断迭代和改进的过程,保持好奇心和耐心,你将在这个领域走得更远。
|
3月前
|
消息中间件 存储 算法
实战算法的基础入门(2)
实战算法的基础入门
|
3月前
|
算法 大数据
实战算法的基础入门(1)
实战算法的基础入门
|
3月前
|
算法 Java
实战算法的基础入门(3)
实战算法的基础入门
下一篇
无影云桌面