两道Java作业题

1、将一维数组中的元素序列输出成循环移位方阵,可指定移位方向和移动位数。


 
例如,将{7,4,8,9,1,5}序列元素按右移一位方式输出的循环移位方阵如下:


 
7 4 8 9 1 5


 
5 7 4 8 9 1


 
1 5 7 4 8 9


 
9 1 5 7 4 8


 
8 9 1 5 7 4


 

4 8 9 1 5 7


 import java.util.Scanner;


class  asd
{
public static void main(String[] args) 
{
int a[];
 a=new int[]{7,4,8,9,1,5};
for ( int j=0;j<a.length ;j++ )
{
System.out.print(a[j]+" ");
}
System.out.println("请输入一个小于6的正数m代表右移动格数 负数代表向左移动格数");
Scanner myScanner=new Scanner(System.in);
int m=myScanner.nextInt();
int k=m;
if(m>0){
for(int i=0;i<m;i++){
System.out.print(a[6-k]+" ");
k--;
}
for(int i=0;i<(6-m);i++){
System.out.print(a[i]+" ");
}

}
if(m<0)
{
m=6+m;
k=6+k;
for(int i=0;i<m;i++){
System.out.print(a[6-k]+" ");
k--;
}
for(int i=0;i<(6-m);i++){
System.out.print(a[i]+" ");
}
}
myScanner.close();


}

}

2、找出一个二维数组的鞍点。
鞍点指某数组元素的值在该行上最大、在列上最小。也可能没有鞍点。

 public class andian {
public static void main(String[] args) {
int i,j,maxofrow,maxofcol;
int[][] a = {{3,2,1},{4,2,2},{5,3,3}};
for ( i = 0; i<3; i++ ) {
maxofrow = a[i][0];
maxofcol = 0;
for ( j=1; j<3; j++ ) {
if ( maxofrow<a[i][j] ) {
maxofrow = a[i][j];
maxofcol = j;
}
}//找出了行最大
for ( j=0; j<3; j++ ) {
if ( maxofrow >a[j][maxofcol] ) {
System.out.println("第"+i+"行无鞍点");break; }
else{
System.out.println("第"+i+"行有鞍点,鞍点是"+maxofrow); break;

}
}

}
}
}



java编写的计算器,能实现加减乘除。 //***该梦幻计算器与Windows附件自带计算器的标准版功能、界面相仿***// //******但还不支持键盘操作,如有需要,下一次等级将满足你**********// import java.awt.*; import java.lang.*; import javax.swing.*; import javax.swing.event.*; import java.awt.event.*; import java.awt.Component.*; import java.awt.color.*; import java.text.DecimalFormat; //*****************************************************************************// //*****************************************************************************// public class Calculator implements ActionListener //导入动作监听接口 { //******************************// //*****设计计算器界面的单位*****// JFrame frame; //定义框架 JTextField textAnswer; //定义输出显示框 JPanel panel, panel1, panel2, panel3;//定义面板作为子容器,从而达到要求的界面效果 JMenuBar mainMenu; JTextField textMemory; JLabel labelMemSpace; //labelMemSpace单纯做摆设,控制面板的形状 JButton buttonBk, buttonCe, buttonC; JButton button[]; JButton buttonMC, buttonMR, buttonMS, buttonMAdd; JButton buttonDot, buttonAddAndSub, buttonAdd, buttonSub, buttonMul,buttonDiv, buttonMod; JButton buttonSqrt, buttonDao, buttonEqual; JMenu editMenu, viewMenu, helpMenu; JMenuItem copyItem, pasteItem, tItem, sItem, numberGroup, topHelp, aboutCal,myCollege; DecimalFormat df; //设置数据输出精度 boolean clickable; //控制当前能否按键 double memoryd; //使用内存存储的数字 int memoryi; double vard, answerd; //用来保存double型数据的间值(vard)和最后结果(answerd) short key = -1, prekey = -1; //key用来保存当前进行何种运算,prekey用来保存前次进行何种运算 boolean clear = false; String copy; //做复制用 JTextArea help; //帮助 JScrollPane scrollHelp; static boolean One =true; //******************// //*****构造函数开始*****// public Calculator() { clickable = true; answerd = 0; frame = new JFrame("梦幻计算器--SWE08008"); frame.setResizable(false);//不允许改变计算器的大小 frame.setLocation(250,150);//设置计算器的起始位置 frame.setBackground(Color.YELLOW); df = new DecimalFormat("0.##############"); //设置数据输出精度(对于double型值)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值