当前位置: 首页 > article >正文

Java(day7)

字符串练习

生成验证码

package day6;
/*生成验证码
内容:可以是小写字母,也可以是大写字,还可以是数字
规则:
长度为5
内容中是四位字母,1位数字。
其中数字只有1位,但是可以出现在任意的位置。*/
import java.util.Random;
import java.util.StringJoiner;

public class test6 {
    public static void main(String[] args) {
        Random r=new Random();
        String arr1="qwertyuiopasdfghjklzxcvbnm",
                arr2="QWERTYUIOPASDFGHJKLZXCVBNM",
                arr3="1234567890";
        boolean flag=false;//记录数字是否出现
        StringBuilder a=new StringBuilder();
        for (int i = 0; i < 5; ) {
            int b=r.nextInt(1,4);
            //随机生成1-3,1就小写字母,2就大写字母,3就数字
            if(b==1)
            {
                int c=r.nextInt(0,arr1.length());//生成随机索引
                a.append(arr1.charAt(c));
                i++;
            }
            else if(b==2){
                int c=r.nextInt(0,arr2.length());//生成随机索引
                a.append(arr2.charAt(c));
                i++;
            }
            else if(b==3){
                if(!flag){
                    int c=r.nextInt(0,arr3.length());//生成随机索引
                    a.append(arr3.charAt(c));
                    flag=true;
                    i++;
                }
                else
                    ;
            }
        }
        System.out.println("生成的验证码是:"+a.toString());
    }
}

字符串乘积

package day6;
/*给定两个以字符申形式表示的非负整数num1和num2,返回numd和lnum2的乘积,它们的乘积也表示为字符申形式
注意:需要用已有的知识完成*/
public class test7 {
    public static void main(String[] args) {
        String num1="66",num2="100";
        char arr1[] = new char[num1.length()];char arr2[]= new char[num2.length()];
        //String 类型的变量num1,num2转变为char类型的数组
        for (int i = 0; i < num1.length(); i++) {
            arr1[i]=num1.charAt(i);
        }
        for (int i = 0; i < num2.length(); i++) {
            arr2[i]=num2.charAt(i);
        }
        int x=0,y=0,k=1,j=1;//x接收num1,y接受num2
        for (int i = arr1.length-1; i >=0 ; i--) {
            x+=(int)(arr1[i]-'0')*k;
            k*=10;
        }
        for (int i = arr2.length-1; i >=0 ; i--) {
            y+=(int)(arr2[i]-'0')*j;
            j*=10;
        }
        int result=x*y;
        StringBuilder a=new StringBuilder();//接收结果
        while (result>0){
           a.append((char)((result%10)+'0'));
           result/=10;
        }
        StringBuilder b=a.reverse();
        System.out.println(b.toString());
    }
}

字符串最后一个单词

package day6;
/*给你一个字符串s,由若干单词组成,单词前后用一些空格字符隔开。
返回字符串中最后一个单词的长度。
词是指仅由字母组成,不包含何格字符的最大子字符中
示例1;输入;s="he11owor1d" drr输出:5
解释:最后一个单词是"wor1d",长度为5.
示例2:输入:s="f1ymeto themoon 输出:4
解释:最后一个单词是"moon",长度为4.
示例3:输入:s="1uffyissti11joyboy" 输出:6
解释:最后一个单词是长度为6的"joyboy".*/
public class test8 {
    public static void main(String[] args) {
        String s = "Hello World   ";
        // 去除字符串末尾的空格
        s = s.trim();
        int lastIndex = -1;
        for (int i = s.length() - 1; i >= 0; i--) {
            if (s.charAt(i) == ' ') {
                lastIndex = i;
                break;
            }
        }
        int result;
        if (lastIndex == -1) {
            result = s.length();
        } else {
            result = s.length() - lastIndex - 1;
        }
        System.out.println("最后一个单词的长度为: " + result);
    }
}


http://www.kler.cn/a/488300.html

相关文章:

  • springboot整合拦截器
  • C#,图论与图算法,输出无向图“欧拉路径”的弗勒里(Fleury Algorithm)算法和源程序
  • Redis数据库笔记——主从复制
  • 音视频入门基础:MPEG2-PS专题(6)——FFmpeg源码中,获取PS流的视频信息的实现
  • SpringBoot3动态切换数据源
  • ProtonBase 荣获 Datafun “数智技术最佳探索奖”
  • HTTP 与 HTTPS 网络传输
  • Linux -- 初步了解 TCP 编程
  • ubuntu 20.04 安装 5.4 内核
  • CClinkIEfield Basic转Modbus TCP网关模块连接三菱FX5U PLC
  • 关于物联网的基础知识(四)——国内有代表性的物联网平台都有哪些?
  • xml-dota-yolo数据集格式转换
  • 【FPGA】时序约束与分析
  • 部署langchain服务
  • 使用 FastAPI 和 Async Python 打造高性能 API
  • 超大规模分类(三):KNN softmax
  • cJson——序列化格式json和protobuf对比
  • 单元测试MockitoExtension和SpringExtension
  • poi处理多选框进行勾选操作下载word以及多word文件压缩
  • Cognitive architecture 又是个什么东东?
  • 【Rust自学】11.7. 按测试的名称运行测试
  • 记录一个移动端表格布局,就是一行标题,下面一列是对应的数据,一条一条的数据,还有点击数据进入详情的图标,还可以给一列加input输入框,还可以一对多
  • dubbo3 负载均衡
  • js迭代器模式
  • python+camelot库:提取pdf中的表格数据
  • 工厂人员定位管理系统方案(二)人员精确定位系统架构设计,适用于工厂智能管理