字符数组反转_字符数组的初始化

字符数组反转_字符数组的初始化关于字符串的反转,倒是很简单,但是编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组char[]的形式给出。不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用O(1)的额外空间解决这一问题。你可以假设数组中的所有字符都是ASCII码表中的可打印字符。示例1:输入:[“h”,“e”,“l”,“l”,“o”]输出:[“o”,“l”,“l”,“e”,“h…

大家好,又见面了,我是你们的朋友全栈君。

关于字符串的反转,倒是很简单,但是编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 char[] 的形式给出。

不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。

你可以假设数组中的所有字符都是 ASCII 码表中的可打印字符。

示例 1:

输入:[“h”,“e”,“l”,“l”,“o”]
输出:[“o”,“l”,“l”,“e”,“h”]

开辟新的字符数组空间倒是简单的很,如下

class sad{
    public char [] yoyo (char [] a ){
        int q=a.length;
        char [] k=new char [q];
        for(int i=0;i<a.length;i++){
            k[q-i-1]=a[i];
        }
        for(int j=0;j<q;j++){
            System.out.print(k[j]);

        }
        return k;
    }


}


public class charobease {
    public static void main(String args[]){

        sad s=new sad();
        char [] l={'h','e','l','l','o'};
        s.yoyo(l);


    }
}

直接遍历原数组放在新的数组里,但是如何才能不开辟新的数组呢

class sad{
    public char [] yoyo (char [] a ){
        int q=a.length;

        for(int i=0;i<a.length/2;i++){
          char temp=a[i];
          a[i]=a[q-1-i];
          a[q-1-i]=temp;
        }
        for(int j=0;j<q;j++){
            System.out.print(a[j]);

        }
        return a;
    }


}


public class charobease {
    public static void main(String args[]){

        sad s=new sad();
        char [] l={'h','e','l','l','o'};
        s.yoyo(l);


    }
}

给定一个字符串,你需要反转字符串中每个单词的字符顺序,同时仍保留空格和单词的初始顺序。

示例 1:

输入: “Let’s take LeetCode contest”
输出: “s’teL ekat edoCteeL tsetnoc”

class Solution {
    public String reverseWords(String s) {
        String [] aa= s.split(" ");
     StringBuilder sb = new StringBuilder();
	     int size =0;//不能在循环里面初始化,不然它会反复初始化
	    for(int i=0;i<aa.length;i++) {
	    	char [] ch=aa[i].toCharArray();
	    	for(int j=0;j<ch.length/2;j++) {
	    		int p=aa[i].length();
	    		char temp=ch[j];	  	
	    		ch[j]=ch[p-j-1];
	    		ch[p-j-1]=temp;
	    		
	    		
	    	}
            sb.append(ch);
	    	
	    	 size++;
	    	
	    	 if(size != aa.length){
	              sb.append(" "); 
	            }
	    }
     return sb.toString();
    }
}
class happy{
    public String shishi (String s, int k){
   char [] c=s.toCharArray();
for(int i=0;i<s.length();i=i+2*k)  {
    int size=i+k-1;
    for(int j=i,b=size;j<=(i+size)/2;j++,b--)
    {
        char temp=c[j];
        c[j]=c[b];
        c[b]=temp;


    }
}
        for(int e=0;e<s.length();e++){
            System.out.print(c[e]);

        }
return  new String(c);
    }


}




public class test {
    public static void main(String args[]){
        happy h=new happy();
        String sb="hhssfiadsofgdiogf";
        int p=3;
        h.shishi(sb,3);


    }
}

给定只含 “I”(增大)或 “D”(减小)的字符串 S ,令 N = S.length。

返回 [0, 1, …, N] 的任意排列 A 使得对于所有 i = 0, …, N-1,都有:

如果 S[i] == “I”,那么 A[i] < A[i+1]
如果 S[i] == “D”,那么 A[i] > A[i+1]

示例 1:

输出:“IDID”
输出:[0,4,1,3,2]

class boring {
    public int[] training(String a) {
        int N = a.length();
        int pos = 1;
        int neg = -1;
        int[] clk = new int[N + 1];
        char[] ch = a.toCharArray();
        for (int i = 0; i < N; i++) {
            if (ch[i] == 'I') {
                clk[i] = clk[i] + pos;
                pos++;
            } else {
                clk[i] = clk[i] + neg;
                neg--;

            }

        }
        int p = -neg - 1;
        int[] ar = new int[N + 1];
        for (int j = 0; j <= N; j++) {
            ar[j] = clk[j] + p;

        }
        for (int k=0;k<=N;k++) {
            System.out.print(ar[k]);


        }
        return ar;
    }

}


public class leetcode0404 {

    public static void main(String[] args) {
        String sb = "IDID";
        boring b = new boring();
        b.training(sb);

    }
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/135403.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 深度学习、机器学习方向计算机毕业设计题目大全(算法应用实践类)

    深度学习、机器学习方向计算机毕业设计题目大全(算法应用实践类)(吐血整理)手动整理了1500多个深度学习及机器学习相关算法在实际应用中的项目,完全可以作为本科生当前较新的毕业设计题目选择方向。讲道理有些题目,比如“用户评分的隐式成分信息的研究”这种题目取的就比较广,有点科学研究的味道,如果真的去做,还是比较有技术含量的。因为其下一步的应用是具有广阔前景的。还有部分项目可能需要大量的数据集,收集的收集和整理比较麻烦。另外对自己电脑的要求也比较高。大家在选择…

    2022年5月7日
    109
  • 【超实用】各种单位换算表大全

    【超实用】各种单位换算表大全面积换算1平方公里(km2)=100公顷(ha)=247.1英亩(acre)=0.386平方英里(mile2)1平方米(m2)=10.764平方英尺(ft2)1平方英寸(in2)=6.452平方

    2022年7月4日
    26
  • SQLPLUS登陆命令「建议收藏」

    一.SQLPLUS登陆命令:使用sqlplus:10G之前的版本登陆时需要加引号(单、双引号皆可)如:sqlplus"/assysdba"sqlplus-prelim/assysdba&nbsp;&nbsp;&nbsp;&nbsp;从Oracle10g开始,sqlplus提供了一个参数选项-prelim,用这个参数,在系统已经hang的时候可以连接到SGA而不是数据库,也就…

    2022年4月10日
    70
  • idea中撤销操作_eclipse反撤销快捷键

    idea中撤销操作_eclipse反撤销快捷键在刚使用idea的小伙伴都会遇到这样一个问题就是,习惯性地使用ctrl+y进行反撤销。但是却把该行代码删除了,哈哈哈:D.这谁都遇到过的。因为在idea中ctrl+y就是删除该行的快捷键,那么在idea中的反撤销快捷键是什么呢?其实是,ctrl+shift+z。但是可能你用了还是没效果,那是因为你PC上别的软件占用了该快捷键。我知道的就有搜狗输入会占用该快捷键~那我们取消搜狗输入法的这个快捷键…

    2022年10月2日
    5
  • oracle分页查询的三种常见方式

    oracle分页查询的三种常见方式oracle分页查询的三种常见方式分页写法:–分页查询一select*from(selectrownumr,e1.*from(select*fromemporderbysal)e1whererownum&lt;=8)wherer&gt;=5;–分页查询二selecte1.*from…

    2022年5月8日
    50
  • numpy中的meshgrid函数「建议收藏」

    numpy中的meshgrid函数「建议收藏」numpy官方文档meshgrid函数帮助文档https://docs.scipy.org/doc/numpy/reference/generated/numpy.meshgrid.html meshgrid(*xi,**kwargs)功能:从一个坐标向量中返回一个坐标矩阵 参数:x1,x2…,xn:数组,一维的数组代表网格的坐标。indexing:{‘xy’,…

    2022年6月4日
    31

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号