【CSDN编程竞赛·第四期】个人参赛经历和个人建议

简介: 大家好,我前不久参加了官方举办的CSDN编程比赛,官方举办了四期,第一期的时候没看到,错过了,后面的每一期我都参加了,总的感觉来说,还可以。下面我具体说说第四期相关经验吧。

1、小玉家的电费

时间限制:1000ms                        内存限制:256M

题目描述:

小玉家今天收到了一份电费通知单。上面写着:月用电量在150千瓦时及以下部分按每千瓦时0.4463元执行;月用电量在151~400千瓦时的部分按每千瓦时0.4663元执行;月用电量在401千瓦时及以上部分按每千瓦时0.5663元执行。请根据电价规定,计算出应交的电费应该是多少。


输入描述:

输入一个整数,表示用电总计(单位以千瓦时计),不超过10000。


输出描述:

输出一个数,保留到小数点后1位(单位以元计,保留到小数点后一位)。


示例:

输入

267

输出

121.5


代码及思路:

题目言简意赅,纯签到,照着题目写就完事了.用c语言就可以实现,三个条件语句,这题比较简单。

#include <stdio.h>
float solution(int m){
float result;
if(m<=150)
result=m*0.4463;
else if (m<=400)
result=150*0.4463+(m-150)*0.4663;
else ;
// TODO: 请在此编写代码
return result;
}
int main() {
int m;
scanf("%d", &m);
float result = solution(m);
printf("%.1f", result);
return 0;
}

2、单词逆序

时间限制:1000ms                        内存限制:256M

题目描述:

对于一个字符串,请设计一个算法,只在字符串的单词间做逆序调整,也就是说,字符串由一些由空格分隔的部分组成, 你需要将这些部分逆序。 给定一个原字符串A,请返回逆序后的字符串。例,输入”I am a boy!“输出”boy! a am I“


输入描述:

输入一行字符串str。(1 <= strlen(str) <= 10000)


输出描述:

返回逆序后的字符串


示例:

输入

It's a dog!

输出

dog! a It's


代码及思路:

建立个二维数组就可以,函数原型:int wordReverse(char s,char wd[10][20]),接收字符串,并把串中单词提取出来存放在二维数组wd[10][20]中,函数返回单词数量。逆序后的单词,在主函数中输出。

#include<stdio.h>
int wordReverse(char *s,char wd[200][200])
{
 int i,j=0,k=0;
 for(i=0;s[i];i++)
 {
  if(s[i]!=' ')
   wd[j][k++]=s[i];
  else
  {wd[j][k]='\0';
  j++;
  k=0;
  }
 }
 wd[j][k]='\0';
 return j;
}
int main()
{
 int i,n;
 char str[10000],word[200][200];
 gets(str);
 n=wordReverse(str,word);
 for(i=n;i>=0;i--)
  printf("%s ",word[i]);
 printf("\n");
 return 0;
}


3、小Q整数分割

时间限制:1000ms                        内存限制:256M

题目描述:

小Q决定吧一个整数n,分割成k个整数。

每个整数必须大于等于1。

小Q有多少方案。

输入描述:

输入整数n,k。(1 <= n, k<= 100)

输出描述:

输出方案数。答案对1e9+7取模。

示例:

输入

3 3

输出

1


代码及思路:

我们可以将整数n看成是由n个1组成的数列,因此每两个1之间就会存在一个间隙,我们可以通过取间隙的方法将n份1分为k段。


因此,我们可以很容易得出n个数就会有n-1个间间隙,要分成k段就需用到k-1个间隙,如此,问题就转化为了我们排列组合问题。方案数 = (n - 1)(n - 2)……(n - k + 1) / 1 / 2 / …… / (k - 1)。


#include<stdio.h>
#include<stdlib.h>
int count;
void select(int step,int cur,int n,int k,int sum)
{
    int i;
    if(sum>n)return;
    if(step>k)
    {
        if(n==sum)
        count++;
        return;
    }
    for(i=cur;i<n;i++)
    {
        select(step+1,i,n,k,sum+i);
    }
}
int main()
{
    int n,k;
    scanf("%d%d",&n,&k);
    printf("%d",count);
    return 0;
}

4、新型美丽数列

时间限制:1000ms                        内存限制:256M

题目描述:

定义美丽数列A:

1. 数列中相邻的数越是靠内相对大小加一,a[2]=a[1]+1,a[n-2]=a[n-1]+1…

2. 距离边缘距离相等的数的大小相等:a[0] = a[n-1],a[1] = a[n-2]…

通过修改数列中的值使得给定数列变成美丽数列。

修改后的值必须仍是正整数。


输入描述:


第一行输入整数n。(1 <= n <= 1000)表示数列的大小。
第二行输入n个整数。

输出描述:

输出最小修改次数。


示例:

输入

1. 3
2. 1 1 1

输出

1


代码及思路:

题目的意思蛮好理解的,就是要实现一个值先递增后递减的列表,同时列表满足相邻的值相差1,及左右对称的金字塔型数列。

很是抱歉,这题我不会解,官方也没有给答案,代码后续会补充。


比赛小结及对官方的建议

小结:

加上本次第四期的比赛,一共是参与了第二期、第三期、第四期,三次比赛。第四期没有再出现第三期出现的选择题类型,还是蛮庆幸的,毕竟之前的选择题覆盖的知识面(语言知识)还是蛮广的,而这次的全编程题倒是能让参赛的大伙更从容一些。


给官方的一些建议:

  1. 首先是题目方面,在描述上可以再清晰准确些,不然容易出现歧义。
  2. 在模板方面,毕竟是编程题,题目直接给出模板后反而更偏向函数题类型。
  3. 希望官方可以出一个模拟考试的入口,和每日一练的编程题相结合。
  4. 官方可以在每次竞赛结束后,可以以直播,博客的形式,解析考试内容的思路。


今天就介绍到这里。

相关文章
|
4月前
|
安全
2024年江西省研究生数学建模竞赛C题: 聚变反应堆设计 问题分析、实现代码及参考论文
本文是关于2024年江西省研究生数学建模竞赛C题的解题分析,题目要求设计聚变反应堆,建立模型分析慢化区/增殖区中温度和中子通量的变化,确定反应堆尺寸以最小化单位电力输出的总成本,并计算相关物理量和分析等离子体的点火要求及稳态运行持续时间。
150 2
|
7月前
|
存储 安全 计算机视觉
参加第十二届中国软件杯比赛感想以及经验
今年我作为参赛选手参加了中国软件杯南京线下赛,参加了总决赛答辩环节,下面总结一些参加比赛的经验以及感受
|
存储 算法
【软考备战·希赛网每日一练】2023年4月25日
关于委托开发:有合同约定,著作权归委托方;而在合同中未约定著作权归属,归创作方。 I/O设备管理软件 层次,从上到下依次为:用户层软件(用户进程)、设备独立性软件(与设备无关的系统软件)、设备驱动程序、硬件。
52 0
|
自然语言处理 安全 测试技术
【软考备战·希赛网每日一练】2023年5月2日
序列图(顺序图)用于展现系统中一个用例和多个对象的行为。 MIME 是一个互联网标准,扩展了电子邮件标准,与安全无关;S/MIME(安全多用途互联网邮件扩展协议)与安全电子邮件相关。
80 0
|
BI C++
【校园微项目竞赛】没勇气参赛?大一拿不到奖?这篇文章将讲述我带领我们组拿下校第一的生猪系统!
【校园微项目竞赛】没勇气参赛?大一拿不到奖?这篇文章将讲述我带领我们组拿下校第一的生猪系统!
71 0
|
算法
第一届全国高校将计算机技能大赛知识点整理
第一届全国高校将计算机技能大赛知识点整理
190 0
|
人工智能 BI Windows
2021 年百度之星·程序设计大赛 - 初赛一、二
2021 年百度之星·程序设计大赛 - 初赛一、二
195 0
2021 年百度之星·程序设计大赛 - 初赛一、二
|
存储
【CSDN编程竞赛 第六期】我的第一场编程竞赛
我的第一场编程竞赛解题思路。
152 0
【CSDN编程竞赛 第六期】我的第一场编程竞赛
|
算法 IDE Java
CSDN编程挑战赛第六期—参赛心得+题解
CSDN编程挑战赛第六期—参赛心得+题解
CSDN编程挑战赛第六期—参赛心得+题解
|
存储 人工智能 分布式计算
想当程序员吗?这11所大学计算机专业堪称国内顶级,高考考生千万不要错过
为大家盘点一下目前国内计算机专业比较好的大学。
320 1
下一篇
DataWorks