codeforces比赛题目 做题总结

本文分析了一个C语言程序,原始版本需判断输入的负数,修正后使用abs()函数将所有数值转换为绝对值,简化条件判断,提升执行效率。输出结果时添加了换行符以保持格式清晰。

2024.2.27

错误版本:刚开始写的提交上去显示超时 

#include <stdio.h>
#include <stdlib.h>

int main()
{
    int a[50];
    int t,i,j,n,sum=0;
    scanf("%d",&t);
    for(i=0;i<t;t++)
    {
        sum=0;
        scanf("%d",&n);
        for(j=0;j<n;j++)
        {
            scanf("%d",&a[j]);
            if(a[j]<0)
            {
                a[j]=-a[j];
            }
            sum+=a[j];
        }
        printf("%d",sum);
    }
    return 0;
}

 提交结果:

修正版本:

#include <stdio.h>
#include <stdlib.h>

int main()
{
    int a[50];
    int t, i, j, n, sum;
    scanf("%d", &t);
    for(i = 0; i < t; i++)
    {
        sum = 0;
        scanf("%d", &n);
        for(j = 0; j < n; j++)
        {
            scanf("%d", &a[j]);
            a[j] = abs(a[j]); // 取绝对值
            sum += a[j];
        }
        printf("%d\n", sum); // 输出结果并换行
    }

    return 0;
}

 提交结果:

总结1:

1.在代码中,输入的数值可能包含负数,而程序在计算每个数的绝对值时使用了 abs() 函数。这样做可以避免负数对计算结果的影响,同时也减少了对条件判断的需求,从而提高了程序的执行效率。因为使用了 abs() 函数,无需再对每个输入的数值进行判断是否为负数,从而避免了额外的比较操作,提高了程序的运行速度。

2.输出一定不要忘记加转行符\n!!!!!

### 三级标题:Codeforces算法题入门指南 Codeforces 是一个由俄罗斯萨拉托夫州立大学的团队创建和维护的算法竞赛平台,它不仅提供了一个做题比赛的环境,还支持博客功能,方便用户之间交流解题思路和技巧[^3]。对于新手来说,Codeforces 提供了丰富的资源来帮助你开始刷算法题。 #### 注册与熟悉环境 首先,你需要注册一个账号。注册过程简单,只需要提供一个有效的电子邮件地址和设置密码。一旦注册成功,你可以通过浏览网站的不同部分来熟悉环境。首页通常会显示最近的比赛信息和热门话题,而“Problems”页面则列出了所有可用的问题供练习。 #### 选择合适的题目 对于初学者而言,建议从较简单的题目开始做起。Codeforces题目按照难度级别进行了分类,你可以通过筛选功能找到那些标记为“div.3”或“div.2”的比赛中的问题,这些通常是更适合新手的题目。随着技能的提升,逐渐挑战更难的问题。 #### 参与比赛 参与在线比赛是提高编程能力的好方法。Codeforces 定期举办各种形式的比赛,包括标准的编程竞赛以及一些特殊的活动。比赛前,请确保阅读比赛规则和要求,这样可以在比赛中避免不必要的失误。比赛结束后,可以查看其他参赛者的解决方案,学习不同的解题策略。 #### 使用社区资源 利用Codeforces自带的博客功能,可以发布自己的解题报告或者向他人求助。此外,很多比赛后都会有官方题解发布,这些都是非常宝贵的学习资料。如果遇到不懂的地方,不要犹豫,积极寻求帮助。 #### 学习工具和技术 为了更好地解决问题,需要掌握一定的数据结构算法知识。推荐书籍如《算法竞赛入门经典》等可以帮助打下坚实的基础。同时,熟悉一种或多种编程语言也是必要的,C++、Java 和 Python 都是常见的选择。 #### 练习模式 除了参加正式的比赛外,还可以利用虚拟比赛或者练习模式来进行自我训练。这种模式下,你可以不受时间限制地尝试解决问题,并且能够反复提交直到满意为止。 #### 持续进步 持续不断地练习是成为优秀程序员的关键。设定个人目标,比如每周解决一定数量的问题,或是定期回顾已解决的问题以加深理解。记住,每个人的学习节奏不同,重要的是保持耐心并享受学习的过程。 ```python # 示例代码 - 快速排序实现 def quick_sort(arr): if len(arr) <= 1: return arr else: pivot = arr[len(arr) // 2] left = [x for x in arr if x < pivot] middle = [x for x in arr if x == pivot] right = [x for x in arr if x > pivot] return quick_sort(left) + middle + quick_sort(right) ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zero_019

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值