【C语言】备战校赛Day1

简介: 【C语言】备战校赛Day1

L1-001 Hello World

题目描述

这道超级简单的题目没有任何输入。

你只需要在一行中输出著名短句“Hello World!”就可以了。

输入样例:

输出样例:

Hello World!


解题代码

int main()
{
    printf("Hello World!");
    return 0;
}

该题较为简单,但要注意输出格式,保险的做法是将输出样例直接复制到printf语句中,较为节省时间并且准确率高.


提交结果


L1-002 打印沙漏

题目描述

本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印:

*****
 ***
  *
 ***
*****

所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。

给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。

输入样例:

19 *

输出样例:

*****
***
 *
***
*****
2


解题代码

#include<stdio.h>
void print(int n,char ch)
{
    int i = 0;
    //打印上半层
    for (i = n; i > 0; i-=2)
    {
        int j = i;//星号数等于层数
        int k = (n - i) / 2;//空格数等于层数-星号数再除2
        while (k > 0)     //循环打印空格
        {
            printf(" ");
            k--;
        }
        while (j > 0)      //再循环打印星号
        {
            printf("%c",ch);
            j--;
        }
        printf("\n");
    }
    //打印下半层
    for (i = 3; i <= n; i+=2)
    {
        int j = i;      //星号数等于层数
        int k = (n - i) / 2;   //空格数等于层数-星号数再除2
        while (k > 0)
        {
            printf(" ");
            k--;
        }
        while (j > 0)
        {
            printf("%c",ch);
            j--;
        }
        printf("\n");
    }
}
 
int main()
{
    int n=0;
    char ch;
    scanf("%d %c",&n,&ch);
    //算层数,层数=顶层**个数
    int sn=n;
    int i=1;
    while(sn>0)//拿sn来从中间层向外减,直到减为负,跳出循环
    {
        i+=2;
        sn-=2*i;
    }
    sn=sn+2*i-1;//最后一步减为负了,我们给它加回去
    i-=2;    //最后一步的i也减超了,加回去得到真实的i
    print(i,ch);   //把层数和字符类型传给函数
    printf("%d",sn);  //打印统计的剩下多余的符号
    return 0;
}

该题的解题步骤为:

  1. 先算层数/最高层符号数(哪个都行,因为这两相等).
  2. 编写打印沙漏函数.(先打印沙漏上半段,再打印沙漏下半段).

更多细节见代码注释.


提交结果


L1-003 个位数统计

题目描述

给定一个 k 位整数 N=dk−110k−1+⋯+d1101+d0 (0≤di≤9, i=0,⋯,k−1, dk−1>0),请编写程序统计每种不同的个位数字出现的次数。例如:给定 N=100311,则有 2 个 0,3 个 1,和 1 个 3。

输入格式:

每个输入包含 1 个测试用例,即一个不超过 1000 位的正整数 N。

输出格式:

对 N 中每一种不同的个位数字,以 D:M 的格式在一行中输出该位数字 D 及其在 N 中出现的次数 M。要求按 D 的升序输出。

输入样例:

100311

输出样例:

0:2
1:3
3:1


解题代码

#include<stdio.h>
#include<string.h>
int main()
{
    char n[1001];//因为N不超过1000位,所以整型没法用
    scanf("%s",n);
    int l=strlen(n);//算n的位数,后面循环要用
    int arr[10]={0};//创建一个数组存放0-9出现的次数
    int i=0,k=0;
    while(l>0)    //遍历n
    {
        i=n[k]-'0';  //i的值就是n的数值
        //因为是字符型,所以要减去符号'0'
        (arr[i])++;
        //i是几就给数组下标的数字+1
        k++;  //访问下一个n数组元素
        l--;  //给遍历长度-1
    }
    //然后循环打印arr数组元素就可以了
    for(i=0;i<10;i++)
    {
        if(arr[i]!=0)//当然,打印的前提是该数字出现次数不等于0
        {
            //数组下标恰好是记录的数字
            printf("%d:%d\n",i,arr[i]);
        }
    }
    return 0;
}

该题解题步骤:

  1. 循环统计n中出现的数字的个数,存入数组中
  2. 循环打印数组即可

更多细节详见代码注释.


提交结果


 



相关文章
|
6月前
|
C语言
【C语言】备战校赛Day2
【C语言】备战校赛Day2
70 0
|
6月前
|
C语言
【C语言】备战校赛Day3
【C语言】备战校赛Day3
65 0
【C语言】备战校赛Day3
|
1月前
|
C语言 C++
C语言 之 内存函数
C语言 之 内存函数
34 3
|
7天前
|
C语言
c语言调用的函数的声明
被调用的函数的声明: 一个函数调用另一个函数需具备的条件: 首先被调用的函数必须是已经存在的函数,即头文件中存在或已经定义过; 如果使用库函数,一般应该在本文件开头用#include命令将调用有关库函数时在所需要用到的信息“包含”到本文件中。.h文件是头文件所用的后缀。 如果使用用户自己定义的函数,而且该函数与使用它的函数在同一个文件中,一般还应该在主调函数中对被调用的函数做声明。 如果被调用的函数定义出现在主调函数之前可以不必声明。 如果已在所有函数定义之前,在函数的外部已做了函数声明,则在各个主调函数中不必多所调用的函数在做声明
22 6
|
27天前
|
存储 缓存 C语言
【c语言】简单的算术操作符、输入输出函数
本文介绍了C语言中的算术操作符、赋值操作符、单目操作符以及输入输出函数 `printf` 和 `scanf` 的基本用法。算术操作符包括加、减、乘、除和求余,其中除法和求余运算有特殊规则。赋值操作符用于给变量赋值,并支持复合赋值。单目操作符包括自增自减、正负号和强制类型转换。输入输出函数 `printf` 和 `scanf` 用于格式化输入和输出,支持多种占位符和格式控制。通过示例代码详细解释了这些操作符和函数的使用方法。
34 10
|
20天前
|
存储 算法 程序员
C语言:库函数
C语言的库函数是预定义的函数,用于执行常见的编程任务,如输入输出、字符串处理、数学运算等。使用库函数可以简化编程工作,提高开发效率。C标准库提供了丰富的函数,满足各种需求。
|
25天前
|
机器学习/深度学习 C语言
【c语言】一篇文章搞懂函数递归
本文详细介绍了函数递归的概念、思想及其限制条件,并通过求阶乘、打印整数每一位和求斐波那契数等实例,展示了递归的应用。递归的核心在于将大问题分解为小问题,但需注意递归可能导致效率低下和栈溢出的问题。文章最后总结了递归的优缺点,提醒读者在实际编程中合理使用递归。
53 7
|
25天前
|
存储 编译器 程序员
【c语言】函数
本文介绍了C语言中函数的基本概念,包括库函数和自定义函数的定义、使用及示例。库函数如`printf`和`scanf`,通过包含相应的头文件即可使用。自定义函数需指定返回类型、函数名、形式参数等。文中还探讨了函数的调用、形参与实参的区别、return语句的用法、函数嵌套调用、链式访问以及static关键字对变量和函数的影响,强调了static如何改变变量的生命周期和作用域,以及函数的可见性。
29 4
|
30天前
|
存储 编译器 C语言
C语言函数的定义与函数的声明的区别
C语言中,函数的定义包含函数的实现,即具体执行的代码块;而函数的声明仅描述函数的名称、返回类型和参数列表,用于告知编译器函数的存在,但不包含实现细节。声明通常放在头文件中,定义则在源文件中。
|
1月前
|
C语言
c语言回顾-函数递归(上)
c语言回顾-函数递归(上)
31 2