蓝桥杯刷题3

news2024/11/19 19:39:09

目录:

1. 天干地支

2. 明明的随机数

3. ISBN号码

4. 缩位求和

5. 幸运数字

6. 串的处理

7. 最长递增

8. 灌溉

9. 特殊日期

10. 最大距离


1. 天干地支

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int year = scan.nextInt();
        String tiangan[] = {"geng","xin","ren","gui","jia","yi","bing","ding","wu","ji"};
        String dizhi[] = {"shen","you","xu","hai","zi","chou","yin","mao","chen","si","wu","wei"};
        System.out.println(tiangan[year%10] + dizhi[year%12]);
        scan.close();
        //40 40%12 = 4
        //0:gengshen
    }
}

求出公元0年的天干地支年,重新排序 

2. 明明的随机数

 

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int num = scan.nextInt();
        HashSet<Integer> studentSet = new HashSet<>();
        
        for(int i = 0; i < num; i++){
            int score = scan.nextInt();
            studentSet.add(score);
        }
        //将一个包含整数的HashSet(studentSet)转换为一个整数数组(studentArray)
        Integer[] studentArray = studentSet.toArray(new Integer[0]);
        Arrays.sort(studentArray);

        System.out.println(studentArray.length);
        for(int i = 0; i < studentArray.length; i++){
            System.out.print(studentArray[i] + " ");
        }
    }
}

3. ISBN号码

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        String s = scan.next();
        String str = s.replace("-","");
        int sum = 0;
        for(int i =0;i<9;i++){
          sum += Integer.parseInt(str.charAt(i)+"") * (i+1);
        }
        
        if((sum%11<10 && sum%11==Integer.parseInt(str.charAt(9)+"")) || (sum%11==10&&str.charAt(9)=='X')){
          System.out.println("Right");
        }else{
          if(sum%11<10){
          System.out.println(s.substring(0,12)+sum%11);
          }else if(sum%11==10){
            System.out.println(s.substring(0,12)+"X");
          }
        }
        scan.close();
    }
}

在Java中,charAt()方法返回的是一个字符类型。当你需要将字符转换为可以被Integer.parseInt()处理的字符串时,需要将其转换为字符串类型。虽然字符本身可以隐式地转换为字符串,但在实际编程中,直接写成 str.charAt(i) + "" 的形式是为了增加代码的可读性,明确表示你想要将字符转换为字符串。

这里的 (str.charAt(i) + "") 相当于显式地将字符转换为了长度为1的字符串。在本例中,由于 Integer.parseInt() 需要接收一个代表整数的字符串作为参数,因此这样的转换是必要的。

4. 缩位求和

import java.math.BigInteger;
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        BigInteger num = scan.nextBigInteger();
        while(num.compareTo(BigInteger.valueOf(9)) > 0){
          num = num.mod(BigInteger.TEN).add(num.divide(BigInteger.TEN));
        }
        System.out.println(num);
        scan.close();
    }
}

5. 幸运数字

import java.util.*;

public class Main {
    public static void main(String[] args) {
        int count = 0;
        for(int i =1;;i++){
          if(check(i,2)==0 && check(i,8)==0 && check(i,10)==0 && check(i,16)==0){
            count++;
          }
          if(count == 2023){
            System.out.println(i);
            break;
          }
        }
    }

    public static int check(int i,int jinzhi){
      int temp = i;
      int he = 0;
      while(i > 0){
        he += i % jinzhi;
        i = i / jinzhi;
      }
      return temp % he;
    }
}

6. 串的处理

import java.util.Scanner;

public class Main{
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String s = scanner.nextLine();
        //将一个字符串按照指定的分隔符拆分成字符串数组
        //表示匹配一个或多个空白字符(包括空格、制表符、换行符等)
        String str[] = s.split("\\s+");
        for (int i = 0; i < str.length; i++) {
          //将当前字符串 str[i] 的第一个字符转换为大写并将剩余部分连接起来
          str[i] = str[i].substring(0, 1).toUpperCase() + str[i].substring(1);
          str[i] = str[i].replaceAll("(\\d)([a-zA-Z])", "$1_$2");
          str[i] = str[i].replaceAll("([a-zA-Z])(\\d)", "$1_$2");
          System.out.print(str[i] + " ");
        }
    }
}
  • (\\d):匹配一个数字,并将其捕获到组1中。
  • ([a-zA-Z]):匹配一个字母,并将其捕获到组2中。

替换字符串是 "$1_$2",其中 $1 和 $2 是反向引用,分别代表匹配到的第一个和第二个捕获组的内容。所以这个操作会查找数字紧接着字母的情况,并在它们之间插入一个下划线。例如,如果 str[i] = "3apple",经过这个操作后,结果变为 "3_apple"

 

7. 最长递增

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int num = scan.nextInt();
        int arr[] = new int[num];
        for(int i = 0;i<arr.length;i++){
          arr[i] = scan.nextInt();
        }
        
        int result = 0;
        int count = 1;
        for (int i = 1; i < num; i++) {
            if(arr[i] > arr[i-1]){
              count++;
              result = result>count ? result:count;
            }else{
              count = 1;
            }
        }
        System.out.println(result);
        scan.close();
    }
}

8. 灌溉

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int n = scan.nextInt();
        int m = scan.nextInt();
        int count1 = scan.nextInt();
        int arr[][] = new int[n][m];
        for(int i = 0;i<count1;i++){
          arr[scan.nextInt()-1][scan.nextInt()-1] = 1;
        }
        int k = scan.nextInt();

        int count = 1;
        for(int i = 0;i<k;i++){
          count ++;
          for(int hang = 0;hang<n;hang++){
            for (int lie = 0;lie<m;lie++){
              if(arr[hang][lie] == count-1){
                if(hang -1 >= 0){
                  arr[hang-1][lie] = count;
                }
                if(hang +1 < n){
                  arr[hang+1][lie] = count;
                }
                if(lie - 1 >= 0){
                  arr[hang][lie-1] = count;
                }
                if(lie+1 < m){
                  arr[hang][lie+1] = count;
                }
              }
            }
          }
        }
        
        int num = 0;
        for(int i =0;i<n;i++){
          for(int j = 0;j<m;j++){
            if(arr[i][j] > 0){
              num ++;
            }
          }
        }
        System.out.println(num);
        scan.close();
    }
}

9. 特殊日期

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        int year = 1900;
        int day = 1;
        int month = 1;
        int months[] = {0,31,28,31,30,31,30,31,31,30,31,30,31};
        
        int count = 0;
        while(true){
          if((year%4 == 0 && year%100 != 0) || year%400 == 0){
          months[2] = 29;
          }else{
            months[2] = 28;
          }
          if(year/1000 + year/100%10 + year/10%10 + year%10 == month/10 + month%10 + day/10 + day%10){
            count++;
          }
          day++;
          if(day>months[month]){
            day = 1;
            month++;
            if(month>12){
              month = 1;
              year++;
            }
          }
          
          if(year==9999 && month==12 && day==31){
            break;
          }
        }
        System.out.println(count);
    }

  
}

10. 最大距离

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int num = scan.nextInt();
        int arr[] = new int[num];
        for(int i = 0;i<arr.length;i++){
          arr[i] = scan.nextInt();
        }
        int max = 0;
        for(int i = 0;i<arr.length;i++){
          for(int j = i+1;j<arr.length;j++){
            int b = Math.abs(i - j) + Math.abs(arr[i] - arr[j]);
            if(b > max){
              max = b;
            }
          }
        }
        System.out.println(max);
        scan.close();
    }
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

spring boot集成Elasticsearch 7.16.3

环境&#xff1a;Elasticsearch 版本 7.16.3 Elasticsearch for windows下载地址 windows 若依 spring boot版本 2.6.0 pom文件添加 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elasticsearch<…

Automated Testing for LLMOps 01:使用CircleCI进行持续集成CI

Automated Testing for LLMOps 这是学习https://www.deeplearning.ai/short-courses/automated-testing-llmops/ 这门课的笔记 Learn how LLM-based testing differs from traditional software testing and implement rules-based testing to assess your LLM application. …

Java实战:构建高效预报名管理系统

✍✍计算机编程指导师 ⭐⭐个人介绍&#xff1a;自己非常喜欢研究技术问题&#xff01;专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目&#xff1a;有源码或者技术上的问题欢迎在评论区一起讨论交流&#xff01; ⚡⚡ Java实战 |…

基于transform的scale属性,动态缩放整个页面,实现数据可视化大屏自适应,保持比例不变形,满足不同分辨率的需求

文章目录 一、需求背景&#xff1a;二、需求分析&#xff1a;三、选择方案&#xff1a;四、实现代码&#xff1a;五、效果预览&#xff1a;六、封装组件&#xff1a; 一、需求背景&#xff1a; 数据可视化大屏是一种将数据、信息和可视化效果集中展示在一块或多块大屏幕上的技…

GL绘制自定义线条4_使用OpenGL ES实现钢笔效果

在以前的文章里http://t.csdnimg.cn/TgCtl&#xff0c;我简述了如何使用OpenGL ES实现光滑的粗线条的绘制效果&#xff0c;在闲暇时间我把它再进一步进化&#xff0c;实现了端点长度按照压感大小实现伸缩的逻辑&#xff0c;从而实现了如下的笔锋效果&#xff1a; 书写过程中的效…

MCBPS配置成SPI

MCBPS配置成SPI 典型的SPI接口 McBSP作为SPI主机 以McBSP为主的SPI接口如图所示。当McBSP被配置为主控器时,发送输出信号(DX)被用作SPI协议的SPISIMO信号,并且接收输入信号(DR)被用作SPISOMI信号。 表列出了将McBSP配置为主控器所需的寄存器位值。下表是有关配置要求…

动环监控是什么?为什么说它是3d可视化机房的眼睛?

在信息化时代的背景下&#xff0c;数据中心机房的重要性日益凸显&#xff0c;传统的人工管理模式显然已经无法应对持续增长的机房数量和规模、日益复杂的网络、频繁更新迭代的资产硬件......搭建3d可视化机房成为了许多企事业单位的共同选择。想要搭建3d可视化机房&#xff0c;…

iOS中卡顿产生的主要原因及优化思路

卡顿本质上是一个UI体验上的问题&#xff0c;而UI的渲染及显示&#xff0c;主要涉及CPU和GPU两个层面。若 CPUGPU渲染耗时超过16.7ms&#xff0c;就会在屏幕vsync信号到来时无法更新屏幕内容&#xff0c;进而导致卡顿。 iOS中UI渲染主要包含Layout->Draw->Prepare->Co…

在原有项目进行业务逻辑开发:同一用户短时间不得提交多次申请,以及更新主表时数据刷新掉了角色权限以及密码重置的问题,详细思路及代码

开发背景&#xff1a; 用户提交表单后&#xff0c;插入到对应数据库表的字段中去&#xff0c;因需要保存是哪一个用户提交的&#xff0c;所以需要拿到主表的user_id&#xff0c;更新功能为记录提交时间&#xff0c;短时间不得再次提交 在对一个已有角色权限分配&#xff0c;登录…

蓝牙耳机和笔记本电脑配对连接上了,播放设备里没有显示蓝牙耳机这个设备,选不了输出设备

环境&#xff1a; WIN10 杂牌蓝牙耳机6s 问题描述&#xff1a; 蓝牙耳机和笔记本电脑配对连接上了&#xff0c;播放设备里没有显示蓝牙耳机这个设备&#xff0c;选不了输出设备 解决方案&#xff1a; 1.打开设备和打印机&#xff0c;找到这个设备 2.选中这个设备&#…

【iOS ARKit】协作 Session 实例

协作 Session 使用注意事项 协作 Session 是在 ARWorldMap 基础上发展起来的技术&#xff0c;ARWorldMap 包含了一系列的地标、ARAnchor 及在观察这些地标和 ARAnchor 时摄像机的视场&#xff08;View&#xff09;。如果用户在某一个位置新创建了一个 ARAnchor&#xff0c;这时…

C++之善用const修饰成员函数

C之善用const修饰成员函数 文章目录 C之善用const修饰成员函数前言1. 约束函数对成员变量的修改2. 允许 const 对象调用3. 在重载函数中提供重载决策总结 前言 ​ 在C编程中&#xff0c;使用const修饰成员函数是一种非常重要的技术手段&#xff0c;它能够提高代码的可维护性、…

基于Python微博舆情数据爬虫可视化分析系统+可视化+情感分析+爬虫+机器学习(完整系统源码+数据库+详细文档)

文章目录 基于Python微博舆情数据爬虫可视化分析系统可视化情感分析爬虫机器学习&#xff08;完整系统源码数据库详细文档&#xff09;源码资料获取在文章末尾1、项目介绍 Pycharm介绍Python语言Echarts简介Navicat Premium 15简介MySQL简介Flask简介 2、项目界面UI详情源码资料…

事物管理(黑马学习笔记)

事物回顾 在数据库阶段我们已学习过事务了&#xff0c;我们讲到&#xff1a; 事物是一组操作的集合&#xff0c;它是一个不可分割的工作单位。事务会把所有的操作作为一个整体&#xff0c;一起向数据库提交或者是撤销操作请求。所以这组操作要么同时成功&#xff0c;要么同时…

Windows PowerShell 命令行历史记录补全

Windows 命令行历史记录补全 使用 powershell 安装PSReadLine 2.1.0 Install-Module PSReadLine -RequiredVersion 2.1.0检查是否存在配置文件 Test-path $profile # 为 false 则执行命令创建 New-item –type file –force $profile编辑配置文件 notepad $profile# 输入如下…

springboot 实现本地文件存储

springboot 实现本地文件存储 实现过程 上传文件保存文件&#xff08;本地磁盘&#xff09;返回文件HTTP访问服务器路径给前端&#xff0c;进行效果展示 存储 服务端接收上传的目的是提供文件的访问服务&#xff0c;对于SpringBoot而言&#xff0c;其对静态资源访问提供了很…

Python程序的流程

归纳编程学习的感悟&#xff0c; 记录奋斗路上的点滴&#xff0c; 希望能帮到一样刻苦的你&#xff01; 如有不足欢迎指正&#xff01; 共同学习交流&#xff01; &#x1f30e;欢迎各位→点赞 &#x1f44d; 收藏⭐ 留言​&#x1f4dd; 年轻是我们唯一拥有权利去编制梦想的时…

VDP (vSphere Data Protection)vsphere备份组件

一 概述 传统的备份&#xff1a;在需要备份的主机上安装备份代理&#xff0c;通过网络连接备份服务器对备份代理发出指令从而将备份数据传输到备份服务器所连接的存储中 不足&#xff1a; 每个虚拟机使用过多的物理资源&#xff08;备份很占资源&#xff09;备份过程中&#…

谷歌SEO推广提高网站点击率的10个秘籍-华媒舍

在当今数字化时代&#xff0c;拥有一个高点击率的网站对于企业和个人而言至关重要。通过谷歌SEO推广&#xff0c;可以帮助网站吸引更多的流量&#xff0c;并在搜索引擎结果页面&#xff08;SERP&#xff09;中获得更好的排名。本文将介绍10个谷歌SEO推广的秘籍&#xff0c;帮助…

高瓴张磊入籍新加坡,这代表了什么?

文&#xff5c;新熔财经 作者&#xff5c;显洋 这两天&#xff0c;海外媒体报道了中国投资大佬与企业家拿到新加坡永居的事儿。本来乏善可陈的文章&#xff0c;却因为一个人名的出现变得有趣起来——高瓴创始人张磊&#xff0c;一位曾经在国内如日中天&#xff0c;但今天鲜少…