J2SE习题(1)

以下为java的一些常见的题

1.

代码:

package cn.wwh.www.exercise;

import java.util.Scanner;

/**
 * 类的作用:1.输出N * N的乘法口诀表
 *
 *
 * @author 一叶扁舟
 * @version 1.0
 * @创建时间: 2014年9月4日 下午6:09:08
 */
public class PrintMultTable {

	public static void main(String[] args) {
		System.out.print("请输入行数:");
		Scanner scn = new Scanner(System.in);
		int num = scn.nextInt();
		printNum(num);
	}

	/**
	 * @param inNum
	 *            控制台输入的整数
	 *
	 */
	private static void printNum(int inNum) {
		if (inNum < 1) {
			System.out.println("输入错误!");
			return;
		}

		System.out.println("输出");
		for (int i = 1; i <= inNum; i++) {
			for (int j = 1; j <= i; j++) {
				System.out.print(j + "*" + i + "=" + (i * j) + "\t");
			}
			System.out.println();
		}

	}

}

2.

package cn.wwh.www.exercise;

import java.util.Scanner;

/**
 * 类的作用: 2.根据输入的起始数和结束数,输出这个范围的所有质数
 *
 *
 * @author 一叶扁舟
 * @version 1.0
 * @创建时间: 2014年9月4日 下午6:26:41
 */
public class PrintPrime {
	public static void main(String[] args) {
		System.out.print("请输入起始数据:");
		Scanner scn = new Scanner(System.in);
		int beginNum = scn.nextInt();
		scn = new Scanner(System.in);
		System.out.print("请输入结束数据:");
		int endNum = scn.nextInt();
		// 调用输出函数
		outPrime(beginNum, endNum);

	}

	/**
	 * @param beginNum
	 *            起始数
	 * @param endNum
	 *            结束数
	 */
	private static void outPrime(int beginNum, int endNum) {
		if (beginNum >= endNum) {
			System.out.println("输入范围错误!");
		}

		int count = 0; // 用于换行
		int sum = 0;// 所有的质数的和
		for (int i = beginNum; i < endNum; i++) {
			if (isPrime(i)) {
				System.out.print(i + "\t");
				sum = i + sum;
				if (++count % 8 == 0)
					System.out.println();

			}
		}

		System.out.println("\ncount:" + count + "\tsum:" + sum);

	}

	/**
	 * @param num
	 *            要判断的整数
	 * @return 如果i是质数则返回true,否则返回false
	 */
	private static boolean isPrime(int num) {
		boolean flag = false;
		if (num <= 1) {
			return flag;
		}
		if (num == 2) {
			return true;
		}

		for (int i = 2; i < num; i++) {
			if (num % i == 0) {
				return flag;
			}
			if (i * i >= num) {
				flag = true;
			}
		}
		return flag;
	}

}

3.

代码:

package cn.wwh.www.exercise;

import java.util.Scanner;

/**
 *类的作用:3.输出水仙花数
 *思路:例如输入一个3位数,则三位的范围是[100,1000)
 *假设判断123?
 *a>temp = 123  last = 123/1%10=3      sum = 3*3*3
 *b>temp = 12  last = 12%10 = 2         sum = sum + 2*2*2
 *c>temp = 1   last = 1%10 = 1          sum = sum + 1* 1*1
 *
 *
 *@author 一叶扁舟
 *@version 1.0
 *@创建时间: 2014年9月4日   下午8:48:25
 */
public class PrintNarcissusNum {

	public static void main(String[] args) {
		System.out.print("请输入数字的位数:");
		Scanner scn = new Scanner(System.in);
		int numLength = scn.nextInt();
		System.out.println(numLength + "位数的水仙花数为:");
		// 输入的最小位数
		int begin = (int) Math.pow(10, numLength - 1);
		for (int i = begin; i < begin * 10; i++) {
			if (isNarcissus(i, numLength)) {
				System.out.print(i + "\t");
			}

		}
	}

	/**
	 * @param i
	 * @return 如果是水仙花数则返回true,否则返回false
	 */
	private static boolean isNarcissus(int num, int length) {
		int temp = 0;
		// 记录所有数字之和
		int sum = 0;
		// 记录各个位上的数字,从右向左记录
		int last = 0;
		for (int i = 0; i < length; i++) {
			int t = (int) Math.pow(10, i);
			temp = num / t;
			last = temp % 10;
			sum = (int) (sum + Math.pow(last, length));
		}
		return sum == num;
	}

}

4.

说明:第一种方法的思路是用数组来模拟一个环形,但是最大的难度是数字的复制,即淘汰数字后将剩下的数字任然组成一个环形。

       第二种方式是直接用循环链表,但是最大的难度是按照题目的格式化输出结果

代码:

第一种方式:

package cn.wwh.www.exercise.selectmonkey;

import java.util.Arrays;
import java.util.Scanner;

/**
 * 类的作用:5.猴子选大王
 *     这种做法有漏洞,并未完善(是个错误的,请勿参考)
 *     本人认为这种思路是对的,只不过有些处理分支有些问题,在此写下,以后有时间再转头仔细研究下
 *
 * @author 一叶扁舟
 * @version 1.0
 * @创建时间: 2014年9月5日 上午12:32:15
 */
public class SelectKing1 {

	public static void main(String[] args) {
		while (true) {
			System.out.print("请输入猴子的个数m:");
			Scanner scn = new Scanner(System.in);
			int total = scn.nextInt();
			scn = new Scanner(System.in);
			System.out.print("请输入淘汰的数字n(n<m):");
			int outNum = scn.nextInt();

			int king = getKing(total, outNum);
			System.out.println("第" + king + "只猴子为猴王!");

		}
	}

	/**
	 * @param total
	 *            猴子的总数
	 * @param outNum
	 *            要淘汰的数字
	 * @return 猴王的编号
	 */
	private static int getKing(int total, int outNum) {

		// 记录返回值的,king的编号
		int king = 0;
		int begin = total;
		int circle = 1;
		boolean flag = true;
		// 初始化数组,数组的长度为total+1,和一个临时数组
		int[] monkey = new int[total + 1];
		int[] temp = new int[total + 1];

		// 让数组中的数据和下标相等
		for (int i = 0; i < total + 1; i++) {
			monkey[i] = i;
		}

		while (flag) {

			// 还剩下一只猴子了
			if (total == 1) {
				king = monkey[1];
				break;
			}
			// 用于一个标志位,用于记录一个数组中最大N的倍数的位置
			int sign = 0;

			if (total != 1)
				System.out.print("第" + circle + "轮报数,");
			// 将这个n的倍数的数组位置置为0,并用sign记录最大的n的倍数下标
			for (int i = 1; i < total + 1; i++) {
				if (i % outNum == 0) {
					System.out.print("第" + monkey[i] + "只猴子因报" + i + "号 退出!");
					monkey[i] = 0;
					sign = i;
				}
			}
			int num = 1;

			if (total > outNum) {
				// 将sing+1-total+1位置
				for (int i = sign + 1; i < total + 1; i++) {
					// if(i >= total +1) break;
					if (monkey[i] != 0) {
						temp[num++] = monkey[i];
					}
				}

				// 1-sign非0位置的数据复制到temp数组中
				for (int i = 1; i < sign; i++) {
					if (monkey[i] != 0) {
						temp[num++] = monkey[i];
						// 剩下了num - 1只猴子了
					}
				}

				// 将temp数组中的数据复制到monkey数组中
				// 首先将monkey全部置为0
				for (int i = 1; i < total + 1; i++) {
					monkey[i] = 0;

				}
				monkey = Arrays.copyOfRange(temp, 0, num);

				if (num - 1 == 1 || num == 1) {
					king = monkey[1];
					flag = false;
				}

				System.out.println("当前退出" + (total + 1 - num) + "只猴子。");
				// 还剩下的猴子数量
				total = num - 1;
				// 报的圈数(轮数)
				circle++;
				if (total == outNum) {
					System.out.print("第" + circle + "轮报数,");
					System.out.print("第" + monkey[outNum] + "只猴子因报" + outNum
							+ "号 退出!");
					System.out.println("当前退出1只猴子。");
					monkey[outNum] = 0;
					total = total - 1;
					circle++;
					continue;
				}

			} else {// 最大标志位小于淘汰数outNum

				while (true) {
					// int leftNum = total;

					int loop = 0;
					int tempNum = 0;

					for (int i = 1; i < begin * 2; i++) {
						tempNum = total * i - outNum;
						loop = i;
						if (tempNum > 0) {
							break;
						} else if (tempNum == 0) {
							loop++;
							break;
						}
					}

					num = 1;
					for (int i = 0; i < loop; i++) {
						for (int j = 1; j < total + 1; j++) {
							temp[num++] = monkey[j];
						}
					}
					if (tempNum == 0) {
						System.out.print("第" + ++circle + "轮报数,");
					}

					System.out.print("第" + temp[outNum] + "只猴子因报" + outNum
							+ "号 退出!");
					System.out.println("当前退出1只猴子。");
					temp[outNum] = 0;
					// System.out.println(Arrays.toString(temp));

					// 首先将monkey全部置为0
					for (int i = 1; i < total + 1; i++) {
						monkey[i] = 0;

					}
					if (tempNum == 0) {
						// System.out.println("num:"+num);
						num = num - 1;
						monkey = Arrays.copyOfRange(temp, outNum, num);
					} else {
						monkey = Arrays.copyOfRange(temp, outNum, num);
					}

					System.out.println("num -1 -outNum:" + (num - 1 - outNum));
					System.out.println("total" + total);
					int m = monkey.length;
					System.err.println(m);
					if (total - 1 != 1 && total - 1 != num - 1 - outNum) {
						for (int i = 1; i < temp.length; i++) {
							monkey[m++] = temp[i];
							System.out.println(Arrays.toString(monkey));
							if (temp[i] == temp[outNum]) {
								break;
							}
						}
					}

					total = total - 1;
					// 还剩下一只猴子了
					if (total == 1) {
						king = monkey[1];
						break;
					}

				}

			}

		}

		return king;
	}

}

第二中方式:

package cn.wwh.www.exercise.selectmonkey;

/**
 * 类的作用:一个猴子实体类
 *
 *
 * @author 一叶扁舟
 * @version 1.0
 * @创建时间: 2014年9月5日 下午10:43:15
 */
public class Monkey {
	// 猴子的编号
	public int no;
	// 当前的猴子的下一个猴子
	public Monkey nextMonkey = null;

	public Monkey(int no) {
		this.no = no;
	}

}
package cn.wwh.www.exercise.selectmonkey;

/**
 * 类的作用:构建一个猴子环形圈
 *
 *
 * @author 一叶扁舟
 * @version 1.0
 * @创建时间: 2014年9月5日 下午10:46:46
 */

public class CycleLinked {

	// 环形圈中猴子的个数
	private int num;
	// 第一个猴子,即编号为1
	private Monkey firstMonkey = null;

	private Monkey tempMonkey = null;

	// 创建一个数量为num的猴子圈
	public CycleLinked(int num) {
		this.num = num;
		for (int i = 0; i < num; i++) {
			// 如果是第一个猴子
			if (i == 0) {
				// 创建一个猴子
				Monkey monkey = new Monkey(i + 1);
				// 指向第一猴子
				this.firstMonkey = monkey;
				this.tempMonkey = monkey;

			} else if (i == num - 1) {// 最后一个猴子
				// 创建一个猴子
				Monkey monkey = new Monkey(i + 1);
				this.tempMonkey.nextMonkey = monkey;
				this.tempMonkey = monkey;
				// 最后一个猴子指向第一个猴子
				this.tempMonkey.nextMonkey = this.firstMonkey;

			} else {
				// 创建一个猴子
				Monkey monkey = new Monkey(i + 1);
				this.tempMonkey.nextMonkey = monkey;
				this.tempMonkey = monkey;

			}
		}

	}

	/**
	 * @param outNum 要淘汰的数字编号
	 *
	 */
	public void specak(int outNum) {

		// 剩下猴子的个数
		int last = this.num;
		// 记录一圈数过的数量
		int count = 0;
		// 记录轮数
		int circle = 1;
		Monkey first = this.firstMonkey;
		Monkey pre = first;
		Monkey delete;
		Monkey prePre = first;

		System.out.print("第" + circle + "轮报数,");

		while (last != 1) {

			// 数n-1下,找到要淘汰的猴子的前一个
			for (int i = 1; i < outNum - 1; i++) {
				while (prePre.nextMonkey.no != pre.no) {
					prePre = prePre.nextMonkey;
					if (prePre.nextMonkey.no == pre.no)
						break;
				}
				// System.out.println("pre.nextMonkey.no "+pre.nextMonkey.no );
				// System.out.println("pre.no"+pre.no);
				// System.out.println("prePre.no"+prePre.no);
				if ((pre.nextMonkey.no > pre.no && count != 0 && pre.no < prePre.no)
						|| (pre.nextMonkey.no < pre.no && count != 0 && pre.no > prePre.no)) {
					System.out.println("当前退出" + count + "只");
					// 以一圈为循环单位,下一个猴子报数大于当前猴子的报数
					circle++;
					System.out.print("第" + circle + "轮报数,");
					count = 0;
				}
				// current = pre.nextMonkey;
				pre = pre.nextMonkey;
				// current = current.nextMonkey;
				while (prePre.nextMonkey.no != pre.no) {
					prePre = prePre.nextMonkey;
					if (prePre.nextMonkey.no == pre.no)
						break;
				}
				// System.out.println("pre.nextMonkey.no "+pre.nextMonkey.no );
				// System.out.println("pre.no"+pre.no);
				// System.out.println("prePre.no"+prePre.no);
				if ((pre.nextMonkey.no > pre.no && count != 0 && pre.no < prePre.no)
						|| (pre.nextMonkey.no < pre.no && count != 0 && pre.no > prePre.no)) {
					System.out.println("当前退出" + count + "只");
					// 以一圈为循环单位,下一个猴子报数大于当前猴子的报数
					circle++;
					System.out.print("第" + circle + "轮报数,");
					count = 0;
				}
			}

			// 删除下一个结点
			delete = pre.nextMonkey;

			pre.nextMonkey = delete.nextMonkey;
			pre = pre.nextMonkey;
			System.out.print("第" + delete.no + "只猴子因报" + outNum + "号 退出!");
			count++;
			while (prePre.nextMonkey.no != pre.no) {
				prePre = prePre.nextMonkey;
				if (prePre.nextMonkey.no == pre.no)
					break;
			}
			// System.out.println("pre.nextMonkey.no "+pre.nextMonkey.no );
			// System.out.println("pre.no"+pre.no);
			// System.out.println("prePre.no"+prePre.no);
			if ((pre.nextMonkey.no > pre.no && count != 0 && pre.no < prePre.no)
					|| (pre.nextMonkey.no < pre.no && count != 0 && pre.no > prePre.no)) {
				System.out.println("当前退出" + count + "只");
				// 以一圈为循环单位,下一个猴子报数大于当前猴子的报数
				circle++;
				System.out.print("第" + circle + "轮报数,");
				count = 0;
			}

			last--;
			if (last == 1) {
				System.out.println("当前退出" + count + "只。");
			}

		}
		System.out.println("第" + pre.no + "只猴子为猴王!");

	}

	public static void main(String[] args) {
		// CycleLinked test = new CycleLinked(7);
		// test.specak(3);
		// Monkey first = test.getFirstMonkey();
		// Monkey temp = first;

		//测试猴子圈是否创建正确
		// do{
		// System.out.println("猴子报数:" + temp.no);
		// temp = temp.nextMonkey;
		// }while (temp != first);

	}

}

package cn.wwh.www.exercise.selectmonkey;

import java.util.Scanner;

/**
 *类的作用:2.采用循环链表的方式处理猴子选王的题目
 *最大的难度就是格式化输出结果(这个是分析+不断的测试的结果)
 *
 *@author 一叶扁舟
 *@version 1.0
 *@创建时间: 2014年9月5日   下午10:42:38
 */
public class SelectKing2 {

	public static void main(String[] args) {

		while (true) {
			System.out.print("请输入猴子的个数m:");
			Scanner scn = new Scanner(System.in);
			int total = scn.nextInt();
			scn = new Scanner(System.in);
			System.out.print("请输入淘汰的数字n(n<m):");
			int outNum = scn.nextInt();

			// 创建一个total长度的猴子圈
			CycleLinked test = new CycleLinked(total);
			// 淘汰猴子,
			test.specak(outNum);

		}
	}

}

时间: 2025-01-02 18:36:19

J2SE习题(1)的相关文章

J2SE习题(2)

第四.五周练习题 1.a. Define a class called BlogEntry that could be used to store an entry for a Weblog. The class should have instance variables to store the poster's username, text of the entry, and the date of the entry using the Date class from this chap

数据库经典习题,

/* 数据导入: Navicat Premium Data Transfer Source Server : localhost Source Server Type : MySQL Source Server Version : 50624 Source Host : localhost Source Database : sqlexam Target Server Type : MySQL Target Server Version : 50624 File Encoding : utf-8

C/C++算法竞赛入门经典Page15 习题1-1 平均数

题目:输入3个整数,输出他们的平均值,保留3位小数. 首先,声明三个整数a,b,c和一个浮点数d: int a,b,c; double d; 输入三个整数a,b,c: scanf("%d%d%d",&a,&b,&c); 将a,b,c取平均值以后复制给d: d=(double)(a+b+c)/3; 最后输出d: printf("%.3lf",d); %.3lf表示保留3位小数的long float. 注意:不能直接这样输出: printf(&q

问题 1018: C语言程序设计教程(第三版)课后习题6.8

/******************************************************************** @file Main.cpp @date 2017-05-12 @author Zoro_Tiger @brief 问题 1018: C语言程序设计教程(第三版)课后习题6.8 http://www.dotcpp.com/oj/problem1018.html *************************************************

SICP 习题 (1.46)解题总结

SICP 习题 1.46 要求我们写一个过程iterative-improve,它以两个过程为参数,其中一个参数用来检测猜测是否足够好,另一个参数用来改进猜测.过程iterative-improve应该返回另一个过程,所返回的过程接收一个参数作为初始猜测,然后不断改进猜测直到结果足够好.题目还要求我们使用iterative-improve重写1.1.7的sqrt过程和1.3.3节的fixed-point过程. 因为涉及到高阶函数,所以整个题目理解起来有一点点费劲.不过这道题作为第一章的收官题确实

C++ Primer 学习笔记_74_面向对象编程 --再谈文本查询示例[续/习题]

面向对象编程 --再谈文本查询示例[续/习题] //P522 习题15.41 //1 in TextQuery.h #ifndef TEXTQUERY_H_INCLUDED #define TEXTQUERY_H_INCLUDED #include <iostream> #include <fstream> #include <sstream> #include <vector> #include <set> #include <map&g

pta 数据结构 习题2.4 递增的整数序列链表的插入(15 分)

习题2.4 递增的整数序列链表的插入(15 分) 本题要求实现一个函数,在递增的整数序列链表(带头结点)中插入一个新整数,并保持该序列的有序性. 函数接口定义: List Insert( List L, ElementType X ); 其中List结构定义如下: typedef struct Node *PtrToNode; struct Node { ElementType Data; /* 存储结点数据 */ PtrToNode Next; /* 指向下一个结点的指针 */ }; type

linux习题回顾

linux习题回顾 1.1 创建一个压缩包/etc,我想让压缩包上面有个日期/时间. [[email protected] ~]# tar zcf /tmp/etc-$(date+%F).tar.gz /etc [[email protected] ~]# ls -l /tmp -rw-r--r--. 1 root root 9731838 Aug  3 19:15 etc-2017-08-03.tar.gz 1.2 已知/oldboy/test.txt文件内容为: oldboy xizi xi

问题 1041: C语言程序设计教程(第三版)课后习题9.8

/******************************************************************** @file Main.cpp @date 2017-05-28 22:02:55 @author Zoro_Tiger @brief 问题 1041: C语言程序设计教程(第三版)课后习题9.8 http://www.dotcpp.com/oj/problem1041.html ****************************************