Second_week_mofangzhen
第二周 奇数阶魔方阵
一、上节回顾
1.数组的基本操作
数组:若干个相同类型变量的集合。
声明:数据类型 数组名称[]; (在栈内存分配空间,存储的是数组的引用地址、数组首元素在堆内存
中的地址)
初始化:为每一个数组元素分配内存空间(堆内存)
访问:通过下标,下标从0开始
属性length
数组的长度,一维数组其长度指的是包含元素个数;二维数组是包含的一维数组的个数。
2.面向过程程序设计
自顶向下、逐步细化。按照程序执行的流程(解决问题的过程)将程序分解为若干个相对独立简单的子
问题。
二、字符串的操作
通过String类。该类位于java.lang
字符串是常量,它们的值不能被创建后改变。支持可变字符串字符串缓冲区。因为字符串对象是不可改
变的,所以它们可以被共享。
1.字符串连接运算符(+)
将两个字符串合并为一个字符串,,将其他类型的数据转换为字符串,并连接形成新的字符串
int a[]; float b[]; int c[][]; int a[]=new int[3]; a[2]=6; 数组名.length int a[]=new int[5]; System.out.println(a.length);//输出5 String s="Hello"; String s1=new String("Hello");
2.方法
String类的方法
length:返回字符串的长度。包含的字符数。
charAt(int n):返回第n个字符,其中的参数n类似数组中的下标值,n值从0开始
toLowerCase():将字符串中的字母全部变为小写字母
toUpperCase():变为大写字母
subString(int beginIndex):从指定位置beginIndex开始到最后一个字符结束,形成新字符串
subString(int beginIndex,int endIndex):指定开始和结束位置,从开始到结束位置中的字符串截
取出来,形成新的字符串。
replace(char oldChar,char newChar):替换,将oldChar替换为newChar
StringBuffer类的方法
deleteCharAt(int index):删除指定位置的字符
insert(int offset,String subStr):在指定位置插入字符串
append(String strOjb):在字符串的末尾添加一个字符串
delete(int beginIndex,int endIndex):从开始到结束,删除字符
3.使用某些系统定义的好的功能时(自定义)
创建类的对象
通过“对象.方法名(参数)”调用相应的方法实现相应的功能。
三、本周练习
1.输入一句英文,统计其中某个字符出现的频率(次数)。
2.输入一句英文,对其进行加密。加密方法自定义。
截取到每一个字符。
3.打印输出蛇形方阵。
二维数组,
String s="Hello";
String s1="World";
String s3=s+s1;//s3的值是HelloWorld
int k=0;
String r=s.substring(k++,k);
if(r.equals("H")){
System.out.println("111");
}else{
System.out.println("2222"); }
import java.util.Scanner;
public class Demo3 {
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
System.out.println("请输入几乘几魔方阵");
int n=sc.nextInt();
int k=1;
int a[][]=new int[n][n];
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
if(i%2==0){
a[i][j]=k++;
}else{
a[i][n-1-j]=k++;
}
}
}
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
System.out.print(a[i][j]+"\t");
}System.out.println();
}
}
}
4.随机生成一个迷宫
随机数的生成、保障生成的随机数必须是0 1,非0 1
5.输出任意奇数阶魔方阵(3、5、7、9)
第一个数填充在第一行中间列,然后下一个数向其右上角填充,如果超出行,则转到最后一行,如果超
出了列,则转到第一列,如果填充的数是该魔方阵的整倍(3阶,3 6),则向下填充。
System.out.println("请输入几乘几魔方阵");
int n=sc.nextInt();
int k=1;
int a[][]=new int[n][n];
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
if(i%2==0){ a[i][j]=k++;
}else{
a[i][n-1-j]=k++; }
}
}
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
System.out.print(a[i][j]+"\t");
}
System.out.println();
}
}
}
Second_week_mofangzhen的更多相关文章
随机推荐
- 使用XPath爬取西刺代理
因为在Scrapy的使用过程中,提取页面信息使用XPath比较方便,遂成此文. 在b站上看了介绍XPath的:https://www.bilibili.com/video/av30320885?fro ...
- LibreOj #539. 「LibreOJ NOIP Round #1」旅游路线
题目链接 做完这道题,我深知当一个问题复杂度过高的时候,把一些可以分离的操作都分散开,可以大幅度降低复杂度..... 发现无论有多少钱,每到一个点后扩展到的距离被限制在 \(min(C, c[i])\ ...
- Java8新增的这些集合骚操作,你掌握了嘛?
目录 Iterable的forEach Iterator的forEachRemaining Collection的removeIf Stream操作 List的replaceAll List的sort ...
- Java NIO之Buffer(缓冲区)
Java NIO中的缓存区(Buffer)用于和通道(Channel)进行交互.数据是从通道读入缓冲区,从缓冲区写入到通道中的. 缓冲区本质上是一块可以写入数据,然后可以从中读取数据的内存.这 ...
- Java 8 新特性:Lambda、Stream和日期处理
1. Lambda 简介 Lambda表达式(Lambda Expression)是匿名函数,Lambda表达式基于数学中的λ演算得名,对应于其中的Lambda抽象(Lambda Abstract ...
- JavaSE06-面向对象
1. 类和对象 1.1 类和对象的理解 客观存在的事物皆为对象 ,所以我们也常常说万物皆对象. 类 类的理解 类是对现实生活中一类具有共同属性和行为的事物的抽象 类是对象的数据类型,类是具有相同属性和 ...
- Security篇:RememberMe
RememberMe功能 rememberMeServices接口 有AbstractRememberMeServices抽象类 PersistentTokenBasedRememberMeServi ...
- Unity2D 人物移动切换人物图片
勾选Constraints_freeze Rotation_z轴锁定,防止碰撞偏移. public float moveSpeed = 3f;//定义移动速度 priv ...
- 【PY从0到1】第三节 列表
# 3 列表 # 1> 下面这就是一个列表 aabbccdd = ['ee','ff','gg'] # 列表可以储存数据,包含其中元素可以有很多,是可修改.有次序的. # 下面展示一下两套索引. ...
- 【原创】Linux PCI驱动框架分析(一)
背景 Read the fucking source code! --By 鲁迅 A picture is worth a thousand words. --By 高尔基 说明: Kernel版本: ...