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.pswp.cn/news/397671.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/397671.shtml
英文地址,請注明出處:http://en.pswp.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…