题目:有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数
import java.util.Scanner;
public class E {
public static void main(String[] args) {
int N =10;
int[] a = new int[N];
Scanner s = new Scanner(System.in);
System.out.println("请输入10个整数:");
for(int i=0; i<N; i++) {
a[i] = s.nextInt();
}
System.out.print("你输入的数组为:");
for(int i=0; i<N; i++) {
System.out.print(a[i] + " ");
}
System.out.print("\n请输入向后移动的位数:");
int m = s.nextInt();
int[] b = new int[m];
for(int i=0; i<m; i++) {
b[i] = a[N-m+i];
}
for(int i=N-1; i>=m; i--) {
a[i] = a[i-m];
}
for(int i=0; i<m; i++) {
a[i] = b[i];
}
System.out.print("位移后的数组是:");
for(int i=0; i<N; i++) {
System.out.print(a[i] + " ");
}
}
}
题目:有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。
import java.util.Arrays;
import java.util.Scanner;
public class E {
public static void main(String[] args) {
Scanner input=new Scanner(System.in);
System.out.println("请输入总人数");
int n=input.nextInt();
boolean [] p=new boolean[n]; //boolean数组表示站成一圈的人,false表示退出
for(int i=0;i<p.length;i++)
p[i]=true; //将数组初始化为true
int t=0,l=p.length;
while(l>1){
for(int i=0;i<p.length;i++){
if(p[i]){ //t用来计数
t++;
if(t==3){ 如果t=3就退出去
t=0;
p[i]=false;
l--;
}
}
}
}
System.out.println("最后的情况 "+Arrays.toString(p)); //转换成数组输出
for(int i=0;i<p.length;i++)
if(p[i]){
System.out.println("原排在第"+(i+1)+"位的人留下了。");
}
}
}
题目:写一个函数,求一个字符串的长度,在main函数中输入字符串,并输出其长度。
import java.util.Scanner;
public class E {
public static void main(String[] args) {
System.out.println("输入一段字符串");
Scanner input=new Scanner(System.in);
String s=input.nextLine();
System.out.println("这个字符串的长度为:"+s.length());
}
}
就不写函数了 直接用JAVA内部函数就行 好歹使用JAVA来写的 应该应用JAVA知识
题目:编写一个函数,输入n为偶数时,调用函数求1/2+1/4+...+1/n,当输入n为奇数时,调用函数1/1+1/3+...+1/n
import java.util.Scanner;
public class E {
public static void main(String[] args) {
System.out.println("输入一个整数");
Scanner input=new Scanner(System.in);
int n=input.nextInt();
double sum=0;
if(n%2==0)
for(int i=2;i<=n;i+=2){
sum+=(double)1/i;
System.out.print("1/"+i);
if(i!=n)
System.out.print("+");
}
else {
for(int i=1;i<=n;i+=2){
sum+=(double)1/i;
System.out.print("1/"+i);
if(i!=n)
System.out.print("+");
}
}
System.out.println("="+sum);
}
}
JAVA没有指针 只能这样子写了
题目:字符串排序
public class E {
public static void main(String[] args) {
int N=5;
String temp = null;
String[] s = new String[N];
s[0] = "matter";
s[1] = "state";
s[2] = "solid";
s[3] = "liquid";
s[4] = "gas";
for(int i=0; i<N; i++) {
for(int j=i+1; j<N; j++) {
if(compare(s[i], s[j]) == false) {
temp = s[i];
s[i] = s[j];
s[j] = temp;
}
}
}
for(int i=0; i<N; i++) {
System.out.println(s[i]);
}
}
static boolean compare(String s1, String s2) {
boolean result = true;
for(int i=0; i<s1.length() && i<s2.length(); i++) {
if(s1.charAt(i) > s2.charAt(i)) {
result = false;
break;
} else if(s1.charAt(i) <s2.charAt(i)) {
result = true;
break;
} else {
if(s1.length() < s2.length()) {
result = true;
} else {
result = false;
}
}
}
return result;
}
}
JAVA