Java面试题:n=2\n1*2*5*6\n--3*4\n\nn=3\n1*2*3*10*11*12\n--4*5*8*9\n----6*7\n如何实现如上结构的数据
今天学长在面试的时候遇到了一道题,然后让大家做一做。
在不看下面的答案之前,悠闲的朋友们一起来抖动一下大脑吧!

以下是我的想法:
import java.util.Scanner;
public class Case02 {
private static Scanner sc = new Scanner(System.in);
public static void main(String[] args) {
System.out.println("n=2\n1*2*5*6\n--3*4\n\nn=3\n1*2*3*10*11*12\n--4*5*8*9\n----6*7\n");
System.out.println("想查看其他数字如上的结构吗?请输入一个数字n:");
int n = sc.nextInt();
int a[] =new int[n*2];
int[] c = null;
for (int i = 1; i < n; i++) {
int x = 0;
//只走一次的for循环
if( i == 1 ){
for (int j = 1; j <= n*(n+1) && i == 1; j++) {
if( j == n*(n+1) ){
System.out.print( j );
a[x] = j;
x++;
}else if( j <= n || j > n*n ){
System.out.print( j + "*");
a[x] = j;
x++;
}
}
System.out.println();
System.out.print("--");
//第一次进入方法是使用的是a数组
c = getNextArray(a, i ,n );
}else{//其他都是c数组
c = getNextArray(c, i ,n );
//用来填充的横岗"--"
String nvl = "";
for (int j = 0; j < i; j++) {
nvl += "--";
}
System.out.print( nvl );
}
//输出
for (int j = 0; j < c.length; j++) {
if( j == c.length-1 ){//排除最后一个*
System.out.print(c[j]);
}else{
System.out.print(c[j]+"*");
}
}
System.out.println();
}
}
/**
* 根据当前行数据来获取下一行数据的值
* @param a 上一个数组
* @param count 第几行
* @param n 用户输入的数字
* @return
*/
private static int[] getNextArray( int[] a ,int count , int n){
int[] b = new int[(a.length/2-1)*2];
int x = 0;
for (int i = 0; i < a.length; i++) {
if( b.length != x ){
//把正中间的两个数删除
if( i < a.length/2-1 ){
b[x] = a[i]+(n-count+1);
x++;
}else if(i > a.length/2){
b[x] = a[i]-(n-count+1);
x++;
}
}
}
return b;
}
}
结果是对的,但是我是根据自己的想法一步一步写下了的。并没有什么技巧,就像我从小就喜欢数学,但是我只喜欢做难题一样,只做自己喜欢的事情。
以下是参考答案:
import java.util.Scanner;
public class Case {
@SuppressWarnings("resource")
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.println("请输入一个数字:");
int n = sc.nextInt();
int c = 0;
int max = n*(n+1);
int r = 0;
for (int i = n; i >= 1; i--) {
for (int j = 0; j < n-i; j++) {
System.out.print("--");
}
for (int k = 0; k < i; k++) {
c++;
System.out.print(c+"*");
}
max = max - i;
r = max;
for (int k = 0; k < i; k++) {
r++;
if(k!=0){
System.out.print("*");
}
System.out.print(r);
}
System.out.println();
}
}
}
世界上聪明的人很多,老实的人很多,努力的人很多。也许你现在这些都做到了,但坚持下来的很少。
所以,不该骄傲,不该浮躁。不该在看到别人不学习时就放弃了自己。
Java面试题:n=2\n1*2*5*6\n--3*4\n\nn=3\n1*2*3*10*11*12\n--4*5*8*9\n----6*7\n如何实现如上结构的数据的更多相关文章
- java面试题(转)
1.面向对象的特征有哪些方面?答:面向对象的特征主要有以下几个方面:- 抽象:抽象是将一类对象的共同特征总结出来构造类的过程,包括数据抽象和行为抽象两方面.抽象只关注对象有哪些属性和行为,并不关注这些 ...
- 收集了50道基础的java面试题
下面的内容是对网上原有的Java面试题集及答案进行了全面修订之后给出的负责任的题目和答案,原来的题目中有很多重复题目和无价值的题目,还有不少的参考答案也是错误的,修改后的Java面试题集参照了JDK最 ...
- 转:Java面试题集(1-50)
Java程序员面试题集(1-50) http://blog.csdn.net/jackfrued/article/details/17403101 一.Java基础部分 1.面向对象的特征有哪些方面? ...
- Java面试题全集(上)转载
Java面试题全集(上) 2013年年底的时候,我看到了网上流传的一个叫做<Java面试题大全>的东西,认真的阅读了以后发现里面的很多题目是重复且没有价值的题目,还有不少的参考答案也是 ...
- 史上最全Java面试题整理(附参考答案)
下列面试题都是在网上收集的,本人抱着学习的态度找了下参考答案,有不足的地方还请指正,更多精彩内容可以关注我的微信公众号:Java团长 1.面向对象的特征有哪些方面? 抽象:将同类对象的共同特征提取出来 ...
- 经典Java面试题收集
1.面向对象的特征有哪些方面? 答:面向对象的特征主要有以下几个方面: 抽象:抽象是将一类对象的共同特征总结出来构造类的过程,包括数据抽象和行为抽象两方面.抽象只关注对象有哪些属性和行为,并不关注这些 ...
- 近5年常考Java面试题及答案整理(一)
下列面试题都是在网上收集的,本人抱着学习的态度找了下参考答案,有不足的地方还请指正. 1.面向对象的特征有哪些方面? 抽象:将同类对象的共同特征提取出来构造类. 继承:基于基类创建新类. 封装:将数据 ...
- 最有价值的50道java面试题 适用于准入职Java程序员
下面的内容是对网上原有的Java面试题集及答案进行了全面修订之后给出的负责任的题目和答案,原来的题目中有很多重复题目和无价值的题目,还有不少的参考答案也是错误的,修改后的Java面试题集参照了JDK最 ...
- Java面试题全集(上)
2013年年底的时候,我看到了网上流传的一个叫做<Java面试题大全>的东西,认真的阅读了以后发现里面的很多题目是重复且没有价值的题目,还有不少的参考答案也是错误的,于是我花了半个月时间对 ...
随机推荐
- csu 1306 Manor(优先队列)
http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1306 1306: Manor Time Limit: 1 Sec Memory Limit: 1 ...
- C#设计模式学习资料--观察者模式
http://www.cnblogs.com/promise-7/archive/2012/05/14/2500759.html http://www.cnblogs.com/zhenyulu/art ...
- 3.6 spring-construction-arg 子元素的使用与解析
对于构造函数子元素是非常常用的. 相信大家也一定不陌生, 举个小例子: public class Animal { public String type; public int age; /** * ...
- 30分钟让你了解MongoDB基本操作
今天记录下MongoDB的基本操作,这只是最基本的,所以是应该掌握的. 数据库 数据库是一个物理容器集合.每个数据库都有自己的一套文件系统上的文件.一个单一的MongoDB服务器通常有多个数据库. 集 ...
- 推荐牛X的一本JS书
主要是看阮一峰的教程时,他参考书目里有这一本中文的, 找来一看,果然高.. 练习一下. function Base(name) { this.name = name; this.getName = f ...
- linux ln命令 创建链接(快捷方式)
命令格式: ln -s 目标地址 链接名称 # 假设/home目录下有wuyou文件夹,你要在当前目录创建一个链接指向它 $ ln -s /home/wuyou wuyou_link
- 6大排序算法,c#实现
using System; using System.Text; using System.Collections.Generic; namespace ArithmeticPractice { st ...
- 封装SqlHelper
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.C ...
- 支付标记化(Tokenization)技术
道客巴巴->支付标记化(Tokenization)技术介绍 百度文库->中国银联支付标记化技术指引 NFC产业网->银联技术专家解答支付标记化Token技术 百度搜索->Tok ...
- P134、面试题22:栈的压入、弹出序列
题目:输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1.2.3.4.5是某栈的压栈序列,序列4,5,3,2,1是该压栈序列对 ...