设为首页 收藏本站
查看: 1281|回复: 0

[经验分享] 2012/3/7华为面试题

[复制链接]

尚未签到

发表于 2016-6-6 10:49:32 | 显示全部楼层 |阅读模式
1.写了个实现了Singleton 模式的类。

//饱汉模式
  public class Singleton{
           private Singleton(){}
   private static Singleton intstance = new Singleton();
   public static Singleton getInstance(){
   
         return instance;
   }
  }
   
//几汉模式
  public class Singleton{
         
   private static Singleton intstance = null;
   public static Synchronized Singleton getInstance(){
   
        if (instance==null){
      instance =new Singleton();
      return instance;
}
   }
  }


2.有一个已定义的父类A,A有一个方法,写一个B类,要求B类继承A,

当启动B时每3秒单线程调用A的方法。

  
public class A {
public static void main(String args[]) {

Thread a = new Thread(new B());
a.start();

}

public void output() {
System.out.println("output() ");
}
}

class B extends A implements Runnable {
B() {
Thread thread = new Thread(this);
}

public void run() {
while (true) {
this.output();
try {
Thread.sleep(3000);
} catch (Exception e) {
}
}
}
}

1.找出某个字符串中重复次数最多的字符

/*在一个字符串中可能包含a-z中的多个字符,如有重复,如String data = "shfksjgljsfsfs",
* 求出现次数最多的那个字母及次数,如有多个重复的则求出。
思路:
1.引入TreeSet,通过集合快速找到所有出现的字符。
2.引入ArrayList,为了快速排序,再通过StringBuffer生成排序后的字符串。
3.通过String Api中基本方法, indexOf lastIndexOf来计算TreeSet中每个字符串出现的最大值。
4.如果出现相同的则把相同的都记录在一个列表中。
5.记录第一个出现次数最多的字符(为了计算多个字符串相同的情况)。
6.计算最大字符串列表中哪些才是真正出现次数最多的。
*/
import java.util.ArrayList;
import java.util.Collections;
import java.util.Iterator;
import java.util.TreeSet;

public class Test2 {
public static void main(String args[]) {
String input = "adsfsafasdfjlfdjgkdf";
new Test2().doString(input);
}

public void doString(String input) {
char[] chars = input.toCharArray();
ArrayList lists = new ArrayList();
TreeSet set = new TreeSet();
for (int i = 0; i < chars.length; i++) {
lists.add(String.valueOf(chars));
set.add(String.valueOf(chars));
}
System.out.println("set========>"+set); // set没有重复的元素
Collections.sort(lists);
System.out.println("list=======>"+lists); // sort排序

StringBuffer sb = new StringBuffer();
for (int i = 0; i < lists.size(); i++) {
sb.append(lists.get(i));
}
input = sb.toString();
System.out.println("input=====>"+input);
int max = 0;
String maxString = "";
ArrayList maxlist = new ArrayList();

Iterator its = set.iterator();
while (its.hasNext()) {
String os = (String) its.next();
int begin = input.indexOf(os);
int end = input.lastIndexOf(os);
int value = end - begin + 1;
if (value > max) {
max = value;
maxString = os;
maxlist.add(os);
} else if (value == max) {
maxlist.add(os);
}
}

int index = 0;
for (int i = 0; i < maxlist.size(); i++) {
if (maxlist.get(i).equals(maxString)) {
index = i;
break;
}
}
System.out.println("出现最多的字符分别是:");
for (int i = index; i < maxlist.size(); i++) {
System.out.println(maxlist.get(i) + "  ");
}
System.out.println();
System.out.println("出现最多的次数为" + max);
}
}

2.写出一个脚本创建一张表,要求有主键有索引(非主键索引)
表通常具有包含唯一标识表中每一行的值的一列或一组列。这样的一列或多列称为表的主键 (PK),
用于强制表的实体完整性。在创建或修改表时,您可以通过定义 PRIMARY KEY 约束来创建主键
创建索引:
CREATE   INDEX   IND_NAME   ON   TABLE_NAME(COL1,COL2,...);
重建索引:
ALTER   INDEX   IND_NAME   REBUILD;
查看索引:
SELECT   *   FROM   USER_INDEXES   WHERE   INDEX_NAME= 'IND_NAME ';

    rt:
      create table tl (Num varchar2(20) primary key ,Num2 varchar2(20));
      create index num_index on tl (num2);


3.页面有个下拉框,用脚本实现更改下拉框的值,假设更改下拉框第五个值,用jquery或js

         var  d = document。getElementById("ddl");
var index =d.selectedIndex;
d.options[index] .value ="change";
      


4.有一个用户信息表,其中有个字段(name),可能有重复姓名的记录
    1.找出哪些姓名重复了
    2.删除姓名重复的记录
            1.select name from tb group by name having count(name)>1;
    2.delect name from tb t where exists (select 1 from tb where emName =t.emName and id <t.id);
    2.delete a from (select *,row = row_number() over (order by getdate()) from ta) a where row > 1

  5.将数组如(-1,1,3,2,7),用升序打印到控制台

      int [] arr ={-1,1,3,2,7};
    arr ===>list ===>Collections.sort(list)====>sys list;

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-226979-1-1.html 上篇帖子: 华为网关短信发送和接收 下篇帖子: 2012/3/16华为电话面试
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表