首页 > 其他分享 >C语言:洛谷数组题目(2)(冰雹猜想,校门外的树,旗鼓相当的对手)

C语言:洛谷数组题目(2)(冰雹猜想,校门外的树,旗鼓相当的对手)

时间:2024-03-14 16:03:17浏览次数:26  
标签:输出 洛谷 题目 int 题解 sum C语言 格式 旗鼓相当

目录

1.前言

2.三则题目

1.冰雹猜想

1.题目描述

2.输入格式

3.输出格式

4.题解

2.校门外的树

1.题目描述

2.输入格式

3.输出格式

4.题解

3.旗鼓相当的对手

1.题目描述

2.输入格式

3.输出格式

4.题解

3.小结


1.前言

今天小蒟蒻继续为大家分享洛谷数组题单题解,一共三道题,希望大家多多支持喔~

2.三则题目

1.冰雹猜想

题目如下:

1.题目描述

给出一个正整数 n,然后对这个数字一直进行下面的操作:如果这个数字是奇数,那么将其乘 33 再加 11,否则除以 22。经过若干次循环后,最终都会回到 11。经过验证很大的数字(7×10117×1011)都可以按照这样的方式比变成 11,所以被称为“冰雹猜想”。例如当 n 是 2020,变化的过程是 20→10→5→16→8→4→2→120→10→5→16→8→4→2→1。

根据给定的数字,验证这个猜想,并从最后的 11 开始,倒序输出整个变化序列。

2.输入格式

输入一个正整数 n。

3.输出格式

输出若干个由空格隔开的正整数,表示从最后的 11 开始倒序的变化数列。

4.题解

先为诸位奉上代码

#include<stdio.h>
int main(){
    int sum[100]={0},n=0;
    int i=0;
    scanf("%d",&n);
    sum[0]=n;
    for(i=1;n!=1;i++){
        if(n%2==1){n=3*n+1;}
        else n=n/2;
        sum[i]=n;
    }
      for(i=i-1;i>=0;i--){
          printf("%d ",sum[i]);
      }
    return 0;
}

这道题主要考察的是数组的基本概念以及倒序输出,先采用一个循环存储输入的数,再利用另一个循环倒序输出,较为基础。

2.校门外的树

题目如下:

1.题目描述

某校大门外长度为 l 的马路上有一排树,每两棵相邻的树之间的间隔都是 11 米。我们可以把马路看成一个数轴,马路的一端在数轴 00 的位置,另一端在 l 的位置;数轴上的每个整数点,即 0,1,2,…,0,1,2,…,l,都种有一棵树。

由于马路上有一些区域要用来建地铁。这些区域用它们在数轴上的起始点和终止点表示。已知任一区域的起始点和终止点的坐标都是整数,区域之间可能有重合的部分。现在要把这些区域中的树(包括区域端点处的两棵树)移走。你的任务是计算将这些树都移走后,马路上还有多少棵树。

2.输入格式

第一行有两个整数,分别表示马路的长度 l 和区域的数目 m。

接下来 m 行,每行两个整数 u,v,表示一个区域的起始点和终止点的坐标。

3.输出格式

输出一行一个整数,表示将这些树都移走后,马路上剩余的树木数量。

4.题解

先为大伙附上代码:

#include<stdio.h>
#include<string.h>
int main() {
    int len[10005] = { 0 }, l = 0, m = 0, sum = 0;
    memset(len, 0, sizeof(len));
    scanf("%d %d", &l, &m);
    for (int q = 0; q < m; q++) {
        int x = 0, y = 0;
        scanf("%d%d", &x, &y);
        for (int i = x; i <= y; i++) {
            len[i] = 1;
        }
    }
    for (int i = 0; i<= l; i++) {
        if (len[i] == 0)sum++;
    }
    printf("%d", sum);
    return 0;
}

这道题的思路是先通过数组将每棵树表示出来并重置,再利用一个循环输入中间需要抛出掉的树(改赋值),最后再遍历整个数组将剩余的树记录并最终打印。(memset函数曾经有在别的博文里面介绍过喔,用兴趣的可以看看哈。、

3.旗鼓相当的对手

1.题目描述

现有 N 名同学参加了期末考试,并且获得了每名同学的信息:语文、数学、英语成绩(均为不超过 150150 的自然数)。如果某对学生 〈i,j〉 的每一科成绩的分差都不大于 55,且总分分差不大于 1010,那么这对学生就是“旗鼓相当的对手”。现在想知道这些同学中,有几对“旗鼓相当的对手”?同样一个人可能会和其他好几名同学结对。

2.输入格式

第一行一个正整数N。

接下来 N 行,每行三个整数,其中第 i 行表示第 i 名同学的语文、数学、英语成绩。最先读入的同学编号为 11。

3.输出格式

输出一个整数,表示“旗鼓相当的对手”的对数。

4.题解

#include<stdio.h>
#include<stdlib.h> 
int main() {
    int student[1001][3], i = 0, j = 0, m = 0, n = 0, N = 0;
    int sum[1001];
    scanf("%d", &N);
    for (i = 0; i < N; i++) {
        for (m = 0; m < 3; m++) {
            scanf("%d", &student[i][m]);
        }
        sum[i] = student[i][0] + student[i][1] + student[i][2];
    }
    for (i = 0; i < N; i++) {
        for (j = i + 1; j <= N; j++) {
            if (abs(student[i][0] - student[j][0]) <= 5 &&
                abs(student[i][1] - student[j][1]) <= 5 &&
                abs(student[i][2] - student[j][2]) <= 5 &&
                abs(sum[i] - sum[j]) <= 10)
                n = n + 1;
        }
    }
    printf("%d", n);
    return 0;
}

这道题相比于前俩道题就比较复杂一点,首先需要创建二维数组,利用嵌套循环将每个学生的三科成绩依次输入,再额外创建一个数组sum来存储总成绩方便比较,接着在利用一个嵌套循环依次比较,最后输出结果,大功告成!

3.小结

今天分享的三道题就到此为止了,希望大家多多支持哦~

标签:输出,洛谷,题目,int,题解,sum,C语言,格式,旗鼓相当
From: https://blog.csdn.net/2301_81073317/article/details/136712077

相关文章

  • 滴水逆向笔记系列-c语言总结6-20.多级指针 数组指针 函数指针-21.位运算-22.内存分配
    第二十课c语言13多级指针数组指针函数指针1.多级指针反汇编一二级指针可以看到p1==*(p1+0)==p1[0]本来一直没想懂为什么是movsxecx,byteptr[eax],是byte,才发现p1是char类型,所以才得用movsx拓展(p1+2)==p1[2],指针可以用和[]取值,他们是一样的(((p3+1)+2)+3)==p3[......
  • 深入C语言指针,使代码更加灵活(二)
    一、数组名的理解前面我们在使用指针访问数组内容的时候,有这样的代码:intarr[10]={1,2,3,4,5,6,7,8,9,10};int*p=&arr[0];在这里我们使用&arr[0]的方式拿到了数组第⼀个元素的地址,但是其实数组名本来就是地址,而且是数组首元素的地址。我们来进行测试:#d......
  • 滴水逆向笔记系列-c语言总结4-15.switch语句反汇编-16.指针1-17.指针2
    第十五课c语言8switch语句初步测试感觉switch在反汇编的语句和if语句的唯一差别就是jcc语句比较集中当分支大于四条时,switch的反汇编开始变3为switch传入的值,1是case最小值,4是case最大值减1,算出偏移量后通过偏移量4加上基址就可以在大表中获取要输出的case语句的地址当现在case......
  • 滴水逆向笔记系列-c语言总结5-
    第十八课c语言11字符串与数组这一节课b站缺失了,参考一下大佬的笔记学习,链接:https://blog.csdn.net/Edimade/article/details/124446533?spm=1001.2014.3001.55021.字符数组:::infochararr[10]={'A','B','C','D','E','F'};//编译器默认在结尾添加......
  • C语言冒泡排序
            冒泡排序是一种简单的排序算法,通过重复遍历要排序的数列,依次比较两个相邻的元素,如果它们的顺序错误则交换它们。这个过程会重复进行,直到没有相邻的元素需要交换,也就是数列已经排序完成。        冒泡排序的名字来源于其工作方式,因为较小的元素会像气......
  • C语言从入门到实战————数组和指针的深入理解
    前言在C语言中,数组和指针有的密切得联系,因为数组名本身就相当于一个指针常量。指针是一个变量,专门用来存储另一个变量的内存地址,通过这个地址可以访问和操作该变量的值,同时也包括数组。数组是一组连续存储的同类型数据的集合,它允许通过索引快速访问各个元素。同时数组名也是数......
  • 滴水逆向笔记系列-c语言总结2-10.变量-11.if逆向-12.正向基础
    第十课c语言31.编码ASCII标准的ASCII编码只需要七位,第八位在拓展ASCII编码使用GB23122.局部变量和全局变量下面代码输出结果为1111(x=11改变了全局的x)第十一课c语言41.内存图2.逆向参数个数3.简单逆向if代码4.if...else...反汇编判断跳转执行一部分代......
  • 滴水逆向笔记系列-7.堆栈图-8.c语言反汇编-9.数据类型
    第七课堆栈图1.函数函数的入口汇编中的函数函数有入口出口,但不一定有返回值和参数2、堆栈windows堆栈:什么是堆栈平衡:第八课c语言分析这段代码的反编译有时候跟反汇编不一定要进函数看,有时候从上下文就能大概猜出函数的作用第九课c语言21、什么是裸函数可以看到......
  • 循环双向链表,精简代码秒懂!(C语言)
    #include<stdio.h>#include<stdlib.h>typedefintE;/***循环双链表*初始化*插入元素*删除元素*求链表总长*@return*/structArrayNode{Ee;structArrayNode*prev;structArrayNode*next;};typedefstructArrayNode*......
  • c语言 线性搜索算法
            线性搜索被定义为一种顺序搜索算法,从一端开始,遍历列表中的每个元素,直到找到所需的元素,否则搜索将继续,直到数据集的末尾。 线性搜索算法 线性搜索算法如何工作?在线性搜索算法中:        1、每个元素都被视为该键的潜在匹配项并进行相同检查。 ......