HW--漂亮度2(测试通过)

 总结:几个函数的使用

(1)  int num=Integer.parseInt(str[0]); //将第一个字符串转成整形数,表示名字个数

(2) String string1=str[i].toLowerCase(); //变小写都

(3)  char ch[]=string1.toCharArray(); //将每一个字符串转成相印的字符数组

(4)  String st=Integer.toString( num1[p]); //将int型转换成字符串型

  (5)   算法层面:计算出每个名字字母出现的个数,排序后,直接按照排序后的计数进行计算就行了,计数最多的是26,一次递减就行了

 

描述

给出一个名字,该名字有26个字符串组成,定义这个字符串的“漂亮度”是其所有字母“漂亮度”的总和。
每个字母都有一个“漂亮度”,范围在1到26之间。没有任何两个字母拥有相同的“漂亮度”。字母忽略大小写。
给出多个名字,计算每个名字最大可能的“漂亮度”。

知识点字符串
运行时间限制0M
内存限制0
输入

整数N,后续N个名字

N个字符串,每个表示一个名字

 

输出

每个名称可能的最大漂亮程度

样例输入2 zhangsan lisi
样例输出192 101

个人电脑测试版本:

package huawei4;
import java.util.Scanner;
public class Beautiful {    public static void main(String[] args){System.out.println("请输入样例:");Scanner scStr=new Scanner(System.in);String in=scStr.nextLine();String str[]=in.split(" "); //存起来,空格分割;          int num=Integer.parseInt(str[0]);  //将第一个字符串转成整形数,表示名字个数int num1[]=new int[num];           //存放每一个名字的漂亮度for(int i=1;i<=num;i++) {int tmp[]=new int[26];                //存放每个名字26个字母分别出现的个数String string1=str[i].toLowerCase();  //变小写都char ch[]=string1.toCharArray();      //将每一个字符串转成相印的字符数组for(int j=0;j<str[i].length();j++){  // 统计个数int k=ch[j]-'a';if((k>=0)&&(k<=26)){tmp[k]++;  //如果在这个范围内加1;
                }}//冒泡对tmpint tmp2;for(int p=tmp.length-1;p>0;p--){for(int q=0;q<p;q++){if(tmp[q+1]<tmp[q]){tmp2=tmp[q];tmp[q]=tmp[q+1];tmp[q+1]=tmp2;}}}//不需要在计算每个字母了,直接遍历字母个数for(int k=0;k<tmp.length;k++) {                      num1[i-1]=num1[i-1]+tmp[k]*(26+k-25);  //如果在这个范围内加1;
                   }}  StringBuffer tt=new StringBuffer();for(int p=0;p<num;p++){String st=Integer.toString( num1[p]); //将int型转换成字符串型tt.append(st);if(p!=num-1)tt.append(" ");  //空格,如果不是最后一个名字
        }      System.out.print(tt);
//        for(int p=0;p<num;p++){
//            System.out.println(num1[p]);
//        }
        }    
}

华为在线OJ版本:

华为测试注意事项:

1、字符串输入的时候一定要用next(),不要使用nextLine();区别是next()可以以空格和enter键当作 分界线

     试验后发现next()方法是以换行或者空格符为分界线接收下一个String类型变量。 

2、输出的时候多行输出的时候换行输出,不要在一行输出,如果一定在一行输出,考虑用print,不要用println

别人的说明:Java的使用Scanner的next()不要用nextline(),再将结果换行输出,应该就可以了;顶,真的就是这个问题
package huawei4;import java.util.Scanner;  
public class Beautiful{      public static void main(String[] args){  Scanner scStr=new Scanner(System.in);  int num=scStr.nextInt();   //名字个数 String name[]=new String[num]; //定义一个字符串数组for(int k=0;k<num;k++){            name[k]=scStr.next();    //
        }          int num1[]=new int[num];                   //存放每一个名字的漂亮度  for(int i=0;i<num;i++) {  int tmp[]=new int[26];                //存放每个名字26个字母分别出现的个数             // String string1=str[i].toLowerCase();  //变小写都  char ch[]=name[i].toCharArray();      //将每一个字符串转成相印的字符数组  for(int j=0;j<name[i].length();j++){  // 统计个数  int k=0; if(ch[j]>='a'&&ch[j]<='z'){k=ch[j]-'a'; }elsek=ch[j]-'A';             if((k>=0)&&(k<=26)){  tmp[k]++;  //如果在这个范围内加1;  
                }  }  //冒泡对tmp  int tmp2;  for(int p=tmp.length-1;p>0;p--){  for(int q=0;q<p;q++){  if(tmp[q+1]<tmp[q]){  tmp2=tmp[q];  tmp[q]=tmp[q+1];  tmp[q+1]=tmp2;  }  }  }  //不需要在计算每个字母了,直接遍历字母个数  for(int k=0;k<tmp.length;k++) {                    num1[i]=num1[i]+tmp[k]*(26+k-25);  //如果在这个范围内加1;  
                 }  }    for(int p=0;p<num;p++){System.out.println(num1[p]);} }      
} 

 

转载于:https://www.cnblogs.com/snowwhite/p/4736137.html

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

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

相关文章

java设计模式 组合_JAVA 设计模式 组合模式

用途组合模式 (Component)将对象组合成树形结构以表示“部分-整体”的层次结构。组合模式使得用户对单个对象和组合对象的使用具有唯一性。组合模式是一种结构型模式。结构图-组合模式结构图Component: 组合中的对象声明接口&#xff0c;在适当的情况下&#xff0c;实现所有类共…

项目总结SpringMVC相关

流程文字概述1、用户发送请求至前端控制器DispatcherServlet2、DispatcherServlet收到请求调用HandlerMapping处理器映射器。3、处理器映射器找到具体的处理器&#xff0c;生成处理器对象及处理器拦截器(如果有则生成)一并返回给DispatcherServlet。4、DispatcherServlet调用Ha…

SpringBoot登录登出切面开发

阅读本文约“2.5分钟” 本文开发环境是SpringBoot2.X版本。 对于系统而言&#xff08;这里多指管理系统或部分具备登录登出功能的系统&#xff09;&#xff0c;登录登出是一个类权限验证的过程&#xff0c;现在一般是以token进行校验&#xff0c;即用户输入登录信息&#xff0c…

4、Cocos2dx 3.0三,找一个小游戏开发Hello World 分析

尊重开发人员的劳动成果。转载的时候请务必注明出处&#xff1a;http://blog.csdn.net/haomengzhu/article/details/27186557Hello World 分析打开新建的"findmistress"项目&#xff0c;能够看到项目文件是由多个代码文件及目录组成的。当中 Hello World 的代码文件直…

spring --aop(日志记录)在工程中实际使用

2019独角兽企业重金招聘Python工程师标准>>> ###1.日志切面 package com.readygo.zbhealth.common;import java.util.Arrays; import java.util.List;import org.aspectj.lang.ProceedingJoinPoint;public class LoggingAspect {public Object Around(ProceedingJoi…

java 多表分页_多表单独查询组合结果的自定义分页(java代码)

多表单独查询组合结果的自定义分页实现(java代码)一、业务需求&#xff1a;遇到一个业务&#xff0c;需要多个表进行分页查询&#xff0c;使用union联合查询时&#xff0c;速度极其缓慢&#xff0c;即使查询的字段添加了索引&#xff0c;union查询好像不走索引&#xff0c;因此…

Neutorn LBaaS 原理

Load Balance as a Service&#xff08;LBaaS&#xff09;是 Neutron 提供的一项高级网络服务。LBaaS 允许租户在自己的网络中创建和管理 load balancer。 load balancer 可以说是分布式系统中比较基础的组件。 它接收前端发来的请求&#xff0c;然后将请求按照某种均衡策略转发…

判断一个图中有无环路的存在

这里要引入两个概念&#xff1a; 1.树边&#xff1a;是一条未被遍历过的边&#xff0c;它指向一个未被访问过的点。 2.反向边&#xff1a;是一条未被遍历过的边&#xff0c;它指向一个被访问过的点。 如果图中有环路的存在&#xff0c;那么环路的最后一个边必然是一条反向边。 …

精选的一些《编程之美》相关资料

又要到一年的招聘季了&#xff0c;肯定又有很多人开始啃《编程之美》了吧。这本书从开阔视野的角度来说很好&#xff0c;不过限于篇幅&#xff0c;有的问题并没有讲清楚&#xff08;甚至问题叙述模棱两可、被标榜为“鼓励同面试官交流以获得更多细节”&#xff09;&#xff1b;…

java 内置函数_java8 四大内置核心函数式接口

其他补充接口&#xff1a;一、Consumer&#xff1a;消费型接口(void accept(T t))来看一个简单得例子&#xff1a;1 /**2 * 消费型接口Consumer3 */4 Test5 public void test1 () {6 consumo(500, (x) -> System.out.println(x));7 }89 public void consumo (double money, …

jQuery - (JQuery datatables api 使用解读)

学习可参考&#xff1a;http://www.guoxk.com/node/jquery-datatables http://yuemeiqing2008-163-com.iteye.com/blog/2006942 分别导入css和js文件 <link href"~/Content/bootstrap.css" rel"stylesheet" /> <link href"~/Content/datatab…

Tomcat配置JNDI数据源

经过3个多小时的努力&#xff0c;配置JNDI数据源(主要是通过DBCP连接池)终于搞定&#xff5e;还是Tomcat官方的说明好&#xff0c;不过全是英文的&#xff0c;大概还看得懂&#xff0e;百度上那么花花绿绿的太多了&#xff0c;一个也没成功&#xff01;&#xff0e;&#xff0e…

java 线程池 固定大小_使用Executors服务在Java中创建固定大小线程池的最佳方法...

查看源代码,您将意识到&#xff1a;Executors.newFixedThreadPool(threadPoolSize);相当于&#xff1a;return new ThreadPoolExecutor(threadPoolSize, threadPoolSize, 0L, MILLISECONDS,new LinkedBlockingQueue());由于它不提供显式的RejectedExecutionHandler,因此使用默认…

令牌验证 token

通过令牌验证在注册中心控制权限&#xff0c;以决定要不要下发令牌给消费者&#xff0c;可以防止消费者绕过注册中心访问提供者&#xff0c;另外通过注册中心可灵活改变授权方式&#xff0c;而不需修改或升级提供者。 可以全局设置开启令牌验证&#xff1a; <!--随机token令…

easybcd 支持 windows 10 和 ubuntu 14.04 双系统启动

家里计算机系统 windows 10 全新安装。 原本是双系统的&#xff0c;还有一个ubuntu。 windows 10 安装以后&#xff0c;恢复ubuntu就是问题了。 (事后经验&#xff1a;请不要立刻安装bcd修改工具) 最初的方法是利用easybcd修改bcd记录。操作是成功的&#xff0c;但系统重新启动…

需求分析与原型设计

结对者&#xff1a;031402140李严 0314026617林瑞斌 需求分析与原型设计 NABCD模型 N&#xff08;Need&#xff0c;需求&#xff09;: 收集信息的过程太过繁琐&#xff0c;有班级总负责人需汇总每一个同学的志愿并填入excel表中&#xff0c;上交年级负责人&#xff0c;年级负责…

java导出表格_java怎么导出excel表格

import com.spire.xls.ExcelVersion;import com.spire.xls.Workbook;import com.spire.xls.Worksheet;public class InsertArray {public static void main(String[] args) {//创建Workbook对象Workbook wb new Workbook();//获取第一张62616964757a686964616fe4b893e5b19e313…

for 循环 和 Array 数组对象

博客地址&#xff1a;https://ainyi.com/12 for 循环 和 Array 数组对象方法 for for-in for-of forEach效率比较 - 四种循环&#xff0c;遍历长度为 1000000 的数组叠加&#xff0c;得到的时间差&#xff1a;for 3for-in 250for-of 7forEach 44- 效率速度&#xff1a;for >…

IntelliJ IDEA---java的编译工具【转】

转自&#xff1a;http://baike.baidu.com/link?urlsEpS0rItaB9BiO3i-qCdGSYiTIVPSJfBTjSXXngtN2hBhGl1j36CYQORKrbpqMHqjvu3MOfkgVzpMqr8To2l2q IDEA 全称 IntelliJ IDEA&#xff0c;是java语言开发的集成环境&#xff0c;IntelliJ在业界被公认为最好的java开发工具之一&#…

OC中文件读取类(NSFileHandle)介绍和常用使用方法

NSFileHandle 1.NSFileManager类主要对于文件的操作(删除&#xff0c;修改&#xff0c;移动&#xff0c;赋值等等) //判断是否有 tagetPath 文件路径&#xff0c;没有就创建NSFileManager *fileManage [NSFileManager defaultManager];BOOL success [fileManage createFileAt…