每日java5-31

  1. 输出描述:输出一个整数,表示最少需要添加的括号数输入(()(()输出2

import java.util.Scanner;

import java.util.Stack;

public class text {

public static void main(String[] args) {

Scanner
sc = new Scanner(System.in);

char[] str = sc.next().toCharArray();

Stack
stack = new Stack<>();

int num = 0;// 多余的右括号

for (char c : str) {

if (c == ‘(’)

stack.push(’(’);

else {

if (!stack.isEmpty())

stack.pop();

else

num++;

}

}

System.out.println(stack.size() + num);

}

}

  1. /*

* 题目描述牛牛和羊羊都很喜欢青草。今天他们决定玩青草游戏。

* 最初有一个装有n份青草的箱子,牛牛和羊羊依次进行,牛牛先开始。

* 在每个回合中,每个玩家必须吃一些箱子中的青草,所吃的青草份数必须是4的x次幂,

* 比如1,4,16,64等等。不能在箱子中吃到有效份数青草的玩家落败。

* 假定牛牛和羊羊都是按照最佳方法进行游戏,请输出胜利者的名字。

输入描述:输入包括t+1行。第一行包括一个整数t(1 ≤ t ≤ 100),表示情况数.

接下来t行每行一个n(1 ≤ n ≤ 10^9),表示青草份数

输出描述:对于每一个n,如果牛牛胜利输出"niu",如果羊羊胜利输出"yang"。

输入3 1
2 3输出niu yang niu

*/

import java.util.Scanner;

public class text {

public static void main(String[] args) {

Scanner sc=new Scanner(System.in);

System.out.println(“输入情况数:”);

int n=sc.nextInt();

System.out.println(“输入m:”);

int m=sc.nextInt();

for(int i=0;i<n;i++) {

System.out.println(“输入青草份数:”);

int x=sc.nextInt();

if(x==1) {

System.out.println(“niu”);

}else if(x%m==0) {

System.out.println(“niu”);

}else {

System.out.println(“yang”);

}

}

}

}

  1. /*

* 输入:[3, 32, 321]输出:[321, 32, 3]

* 解释:通过将数组重新排序,可构造 6 个可能性数字:

* 3+32+321=332321

* 3+321+32=332132

* 32+3+321=323321

* 32+321+3=323213

* 321+3+32=321332

* 321+32+3=321323

* 其中,最小值为 321323,所以,将数组重新排序后,该数组变为 [321, 32, 3]。

*/

  1. 找出一个序列中乘积最大的连续子序列(至少包含一个数)。输入:[2,3,-2,4]输出:6

public class text{

public static void main(String[] args) {

int a[]= {-1,2,-3,4};

System.out.println(minNumbert(a));

}

public static int minNumbert(int[] nums) {

int res = nums[0];

for(int i=0; i<nums.length; i++){

int temp = 1;

for(int j=i; j<nums.length; j++){

temp = temp*nums[j];

res = Math.max(res, temp);

}

}

return res;

}

}

  1. //输入一个字符串,输出该字符串中相邻字符的所有组合。举个例子,如果输入abc,它的组合有a、b、c、ab、bc、abc。(注意:输出的组合需要去重)

public class text{

public static void main(String[] args){

Scanner sc = new Scanner(System.in);

String str = sc.next();

//i代表遍历的字符长度,j代表起始位置,使得生成不同的substring(j, j+1)

for (int i = 1; i <= str.length();
i++) {

TreeSet treeSet = new TreeSet<>();

for (int j = 0; j + i <= str.length(); j++)

treeSet.add(str.substring(j, j + i));

for (String s : treeSet)

System.out.print(s + " ");

}

}

}

147.回文素数

public class text{

public static void main(String[] args){

int r =1000;

int res = 0;

for(int i=2; i<=r; i++)

if(isPrime(i) && isHui(i)) {

res++;

System.out.println(i);

}

System.out.print(“共有”+res+“个”);

}

public static boolean isPrime(int n){

if(n < 2)

return false;

for(int i=2; i<=Math.sqrt(n); i++){

if(n % i == 0)

return false;

}

return true;

}

public static boolean isHui(int n){

String str = String.valueOf(n);

int l=0, r=str.length()-1;

while(l <= r){

if(str.charAt(l) != str.charAt®)

return false;

l++;

r–;

}

return true;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值