循环左移K位后的序列输出

好心人求解救啊啊啊啊啊啊

class Solution {
public:
    string LeftRotateString(string str, int n) {
            int length = str.size();
            int mid = n%length;
            if(mid == 0){
                return str;
            }else{
                int first = 0;                
                int i = mid;
                while(1){
                    str[first] ^= str[i];
                    str[i] ^= str[first];
                    str[first] ^= str[i];
                    ++first;
                    ++i;
                    if(first == mid){//左边结束
                        if(i == length){//右边也结束
                            return str;//返回
                        }else{
                            mid = i;//右边遍历游标赋值给分界点
                        }
                    }else if(i == length){//右边结束
                        i = mid;//分界点赋值给右边遍历游标
                    }
                }
            }
           
        }
};
您的代码已保存
浮点错误:您的程序运行时发生浮点错误,比如遇到了除以 0 的情况
case通过率为0.00%
全部评论
public class Demo11 { public static String LeftRotateString(String str, int k) { if( k <=0 ) { return str; } int offset = k%str.length(); String temp = str+str; int start = str.length()-k; int end = str.length()-1+ (str.length()-k)+1; return temp.substring(start,end); } public static void main(String[] args) { System.out.println(LeftRotateString("abcd", 2)); } } 仅供参考,不知道合不合题意
点赞 回复 分享
发布于 2017-04-16 19:44

相关推荐

2024-11-13 11:12
门头沟学院 Java
咩咩子_:专业技能写上面 项目往下放,如果可以的话改一下学校最好
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务