假期刷题打卡--Day20

1、MT1173魔数

一个数字,把他乘以二,会得到一个新的数字,如果这个新数字依然由原数中那些数字组成,就称原数为一个魔数。输入正整数N,检查它是否是一个魔数,输出YES或者NO。

格式

输入格式:

输入正整数N

输出格式:

输出YES或者NO

样例 1

输入:

142857

输出:

YES
分析过程

看到这个题目的时候,第一想法是将输入数存入到一个数组当中,然后计算出2倍的输入数,然后拿计算出来的数一一和输入数的每一位进行对比。但是,在分析的时候,发现我遗漏了一下条件,这个题目需要实现的是两个条件:

  • 得到的两个数的个数相同,即每个数出现的次数应该是一样的;
  • 得到的两个数中的数字顺序可以不同,但是所含数字是一样的

所以,按照上述条件,我的解决思路是,先将两个数存入到两个数组当中,然后对两个数组里面的元素进行排序,如果每个元素都相同的话,则输出YES,否则输出NO。

        然后,按照这个思路,我写了一段代码:

#include<bits/stdc++.h> 

using namespace std;

int main( )
{
    int n,a[10] = {0},b[10]={0};
    cin >> n;
    int q=n,m = 2 * n,p=m;
    int flag = 1;
    int count=0;
//首先将输入数存入数组中
    while(n!=0){
        a[count]=n%10;
        n/=10;
        count++;
    }
 //然后使用冒泡排序对输入数的元素进行从小到大排序
    for(int i=0;i<count-1;i++){
        for(int j=0;i<count-i-1;i++){//习惯性的把循环变量写成了i,但是在这应该是j
            if(a[j]>a[j+1]){
                int tmp = a[j];
                a[j]=a[j+1];
                a[j+1]=tmp;
            }
        }
    } 
//将输入数的2倍数存入数组中
    while(m!=0){
        count = 0;//count每次放在里面,每次循环都置为0,最终结果只能是1,所以应该放在外面
        b[count]=m%10;
        m/=10;
        count++;
    }
    for(int i=0;i<count-1;i++){
        for(int j=0;i<count-i-1;i++){//这个也是同样的错误
            if(a[j]>a[j+1]){//这里是对b数组排序,而不是a,这里直接复制了,没有修改,应该全部修改为b
                int tmp = a[j];
                a[j]=a[j+1];
                a[j+1]=tmp;
            }
        }
    } 
    for(int z=0;z>count;z++){//这里的判断语句就是错的,如果是>,那么永远无法为NO,所以,这里应该修改为<
        if(a[z]!=b[z]){
            flag = 0;
            break;
        }
    }
    if(flag==1) cout << "YES";
    else cout << "NO";
    return 0;
}

但是,只能通过一个用例:

于是,又开始了找错~

发现了好多个错误,难怪呢,于是,我把错误全部标在了上一个代码中。

修改错误后,得到了我想法的最终代码:

实现代码
#include<bits/stdc++.h> 

using namespace std;

int main( )
{
    int n,a[10] = {0},b[10]={0};
    cin >> n;
    int q=n,m = 2 * n,p=m;
    int flag = 1;
    int count=0,tmp;
//首先将输入数存入数组中
    while(n!=0){
        a[count]=n%10;
        n/=10;
        // cout << a[count];
        count++;
    }
    // cout << count;
 //然后使用冒泡排序对输入数的元素进行从小到大排序
    for(int i=0;i<count-1;i++){
        for(int j=0;j<count-1-i;j++){
            if(a[j]>a[j+1]){
                tmp = a[j];
                a[j]=a[j+1];
                a[j+1]=tmp;
            }
        }
    } 
    // for(int i=0;i<count;i++){
    //     cout << a[i];
    // }
//将输入数的2倍数存入数组中
    count = 0;
    while(m!=0){
        b[count]=m%10;
        m/=10;
        // cout << b[count];
        count++;
    }
    // cout << count;
    for(int i=0;i<count-1;i++){
        for(int j=0;j<count-1-i;j++){
            if(b[j]>b[j+1]){
                tmp = b[j];
                b[j]=b[j+1];
                b[j+1]=tmp;
            }
        }
    } 
    // for(int i=0;i<count;i++){
    //     cout << b[i];
    // }
    for(int z=0;z<count;z++){
        if(a[z]!=b[z]){
            flag = 0;
            break;
        }
    }
    if(flag==1) cout << "YES";
    else cout << "NO";
    return 0;
}

我的这个思路感觉有点繁琐,所以,看了一下评论区的思路。

  • 每个数字出现的次数要相等
  • 用a、b两个数组分别记录两个数中每个数字(0~9)出现的个数,再比较a、b是否相等。

 用这个思路解决,代码行数大大减少(但是对于我来说,很难想到,现在慢慢学吧。):

#include<bits/stdc++.h> 

using namespace std;

int main( )
{
    int n,a[10] = {0},b[10]={0};
    cin >> n;
    int q=n,m = 2 * n,p=m;
    int flag = 1;

    while(n!=0){
        int i=n%10;
        a[i]+=1;
        n/=10;
    }

    while(m!=0){
        int i = m%10;
        b[i]+=1;
        m/=10;
    }
    for(int z=0;z<10;z++){
        if(a[z]!=b[z]){
            flag = 0;
            break;
        }
    }
    if(flag==1) cout << "YES";
    else cout << "NO";
    return 0;
}

2、MT1176两个点的距离

给定笛卡尔平面上两个点的坐标,求它们之间的距离向上舍入为最接近的整数。

格式

输入格式:

输入整型,空格分隔

输出格式:

输出整型

样例 1

输入:

0 0 2 -2

输出:

3
相关知识点
1、笛卡尔平面

笛卡尔坐标系就是直角坐标系和斜坐标系的统称。

2、直角平面间两点的距离公式

    double a = pow((y2-y1),2);

    double b = pow((x2-x1),2);

    double l = sqrt(a+b);

实现代码
#include<bits/stdc++.h> 

using namespace std;

int main( )
{
    int x1,y1,x2,y2;
    cin >> x1 >> y1 >> x2 >> y2;
    double a = pow((y2-y1),2);
    double b = pow((x2-x1),2);
    double l = sqrt(a+b);
    printf("%.0f",l);
    // cout << l;
    return 0;
}

我没理解这个和选择结构有什么区别,不是输入输出类型的题吗。不理解~

3、MT1186do-while循环

请编写一个简单程序,从大到小输出所有小于n的正整数,直到0为止(不含0)。n从键盘输入

格式

输入格式:

输入整型数n

输出格式:

输出整型,空格分隔

样例 1

输入:

10

输出:

10 9 8 7 6 5 4 3 2 1
实现代码

do-while循环不常用,记录一下最基本的用法吧。

#include<bits/stdc++.h> 

using namespace std;

int main( )
{
    int n;
    cin >> n;
    do{
        cout << n << " ";
        n--;
    }while(n>0);
    return 0;
}

do-while语句需要注意的是,while后面需要加一个分号“;”

除此之外,也要注意,循环的基本条件,注意不能写反了。

明天继续吧。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/363893.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

SpringBoot RestTemplate 设置挡板

项目结构 代码 BaffleConfig /*** Description 记录配置信息* Author wjx* Date 2024/2/1 14:47**/ public interface BaffleConfig {// 是否开启挡板的开关public static boolean SWITCH true;// 文件根目录public static String ROOT_PATH "D:\\TIS\\mock";// …

ElementUI Form:Select 选择器

ElementUI安装与使用指南 Select 选择器 点击下载learnelementuispringboot项目源码 效果图 el-select.vue&#xff08;Select选择器&#xff09;页面效果图 项目里el-select.vue代码 <script> export default {name: el_select,data() {return {options: [{value…

LeetCode刷题:使用栈解决150. 逆波兰表达式求值

给你一个字符串数组 tokens &#xff0c;表示一个根据 逆波兰表示法 表示的算术表达式。 请你计算该表达式。返回一个表示表达式值的整数。 注意&#xff1a; 有效的算符为 、-、* 和 / 。每个操作数&#xff08;运算对象&#xff09;都可以是一个整数或者另一个表达式。两个…

泰迪智能科技大模型微调项目训练营已开营

泰迪智能科技大模型微调项目训练营开营 跟张良均老师学大数据人工智能 项目一&#xff1a;医疗诊疗对话意图识别 项目二&#xff1a;中医问答系统 项目三&#xff1a;某平台股票评论情感识别 学习流程&#xff1a; 项目一&#xff1a;医疗诊疗对话…

validator 对象校验,自定义校验实现

一、导入validator工具需要的jar包 <dependency><groupId>org.hibernate</groupId><artifactId>hibernate-validator</artifactId><version>4.1.0.Final</version></dependency><dependency><groupId>javax.valid…

SketchBook 2022下载安装教程,保姆级教程,操作简单,小白也能轻松搞定,附安装包和工具

前言 Autodesk SketchBook是一款新一代的自然画图软件&#xff0c;软件界面新颖动人&#xff0c;功能强大&#xff0c;仿手绘效果逼真&#xff0c;笔刷工具分为铅笔&#xff0c;毛笔&#xff0c;马克笔&#xff0c;制图笔&#xff0c;水彩笔&#xff0c;油画笔&#xff0c;喷枪…

原来你的Windows自带沙盒功能!

什么是Windows沙盒&#xff1f; Windows沙盒是一种虚拟化技术&#xff0c;允许用户在安全隔离的环境中运行不受信任的应用程序。它是Windows 10操作系统的一个特性&#xff0c;旨在提高系统的安全性&#xff0c;防止潜在的威胁对主系统造成影响。 启用Windows沙盒 确保系统满…

【TCP】流量控制和拥塞控制

前言 TCP&#xff08;传输控制协议&#xff09;是互联网协议&#xff08;IP&#xff09;网络传输层协议&#xff0c;负责控制数据包的顺序和流量控制&#xff0c;以防止网络拥塞和数据丢失。TCP流量控制和拥塞控制是确保网络有效通信的重要机制。具体分析如下&#xff1a; 流…

单细胞scRNA-seq测序基础知识笔记

单细胞scRNA-seq测序基础知识笔记 scRNA-seq技术scRNA-seq 分析流程数据预处理聚类标准化数据筛选有用的数据数据降维聚类 Clustering 注释细胞类型 scRNA数据分析结尾 该笔记来源于 B站up 江湾青年 scRNA-seq技术 首先是如何测序&#xff0c;上图瓶中有很多细胞&#xff0c;…

AD24-原理图与PCB交互设置及PCB常用快捷键汇总

一、原理图与PCB交互设置 1、在原理图页&#xff0c;工具-交叉选择模式 2、设置完成后。在原理图页选择器件&#xff0c;然后再PCB页也会相应被选中 3、一般将网络与Pin脚的勾去掉 4、整齐排列 5、TC&#xff1a;查找网络、器件、Pin脚 二、PCB常用快捷键汇总

高效远控管理 向日葵企业版统计报表与自动分组解析

高效远控管理&#xff01;向日葵企业版统计报表与自动分组解析企业之所以引入商用远程控制方案&#xff0c;一个很大的因素就是因为需要对高频率、多设备的远程控制需求以及IT设备本身进行高效管理&#xff0c;因此一款优质的商用远程控制方案势必需要在这些方面搭载足够完善的…

idea查看日志的辅助插件 --- Grep Console (高亮、取消高亮)

&#x1f680; 分享一款很有用的插件&#xff1a;Grep Console &#x1f680; 我们在查看日志的时候可能会有遗漏&#xff0c;使用这款插件可以让特定的关键词高亮&#xff0c;可以达到不遗漏的效果&#xff01; 如果你是一个开发者或者对日志文件分析感兴趣&#xff0c;不要…

MySQL原理(四)索引(3)索引失效与索引区分度

一、索引失效&#xff1a; 首先未使用索引列作为查询条件索引是肯定会生效的&#xff0c;还有其他的情况&#xff0c;索引列做为了查询条件也失效了&#xff1a; ALTER TABLE staffs ADD INDEX idx_staffs_nameAgePos(NAME, age, pos); 1、select 语句、order by语句&#xf…

x2openEuler 升级实操(centos7.8 to openEuler 20.03)

通过 x2openEuler 工具&#xff0c;将 centos 7.8 迁移至 OpenEuler 上&#xff0c;实际感受迁移过程。x2openEuler https://docs.openeuler.org/zh/docs/20.03_LTS_SP1/docs/x2openEuler/x2openEuler.html 环境准备 下载 x2openEuler 安装包 wget https://repo.oepkgs.net/o…

Nicn的刷题日常之带空格直角三角形图案

1.题目描述 描述 KiKi学习了循环&#xff0c;BoBo老师给他出了一系列打印图案的练习&#xff0c;该任务是打印用“*”组成的带空格直角三角形图案。 输入描述&#xff1a; 多组输入&#xff0c;一个整数&#xff08;2~20&#xff09;&#xff0c;表示直角三角形直角边的长度&am…

Linux 指令

Linux 指令 1 登入/登出1.1 关机1.2 重启1.3 切用户 2 文件和目录管理2.1 目录操作2.2 文件操作2.3 文件内容操作2.4 归档及压缩 3 文本编辑器 vim3.1 命令模式3.2 输入模式3.3 末行模式 4 用户和组管理4.1 用户和组帐号概述4.1.1 用户帐号4.1.2 UID和GID 4.2 用户管理 5 组管理…

算法:箱子之形摆放

一、算法描述及解析 要求将一批箱子按从上到下以‘之’字形的顺序摆放在宽度为 n 的空地上&#xff0c;输出箱子的摆放位置&#xff0c; 例如&#xff1a;箱子ABCDEFG&#xff0c;空地宽为3。 如输入&#xff1a; ABCDEFG 3 输出&#xff1a; AFG BE CD 注&#xff1a;最后一行…

leetcode 28.找出字符串中第一个匹配项的下标(python版)

需求 给你两个字符串 haystack 和 needle &#xff0c;请你在 haystack 字符串中找出 needle 字符串的第一个匹配项的下标&#xff08;下标从 0 开始&#xff09;。 如果 needle 不是 haystack 的一部分&#xff0c;则返回 -1 。 示例 1&#xff1a; 输入&#xff1a;haystack…

2023年OceanBase开发者大会:核心内容与学习收获(附大会核心PPT下载)

本次大会邀请了众多业界领袖、技术大咖和开发者&#xff0c;共同探讨数据库领域的技术发展趋势和未来机会&#xff0c;与开发者共同探讨单机分布式、云原生、HTAP 等数据库前沿趋势&#xff0c;分享全新的产品 roadmap&#xff0c;交流场景探索和最佳实践。 一、大会核心内容 …

v-if及v-for、computed计算属性的使用

v-if 概念及使用 v-if是Vue.js中的一个指令&#xff0c;用于根据表达式的真假值条件性地渲染一块内容。如果表达式的值返回真&#xff0c;则Vue会渲染这块内容&#xff1b;如果返回假&#xff0c;则不渲染。 基本用法: <p v-if"isVisible">看到我了吗&#…