問題:輸入 一個字符串 和 一個非負整數N ,要求將字符串循環左移N次。
輸入格式
輸入在第一行 中給出一個不超過 100 個字符長度的、以回車結束的非空字符串;第二行給出非負整數N。
輸出格式:
在一行中輸出循環左移N次後的字符串。
解法一:
#include <stdio.h>
#include <string.h>
int main()
{
char str[100]; //一行字符串輸入的 常規操作:使用字符數組
int N;
int i,l;
gets(str);
scanf("%d",&N);
if(N > (strlen(str))) //字符串長度 與 N的比較
{
N =N%strlen(str);//如果N過大 將其縮減爲有效循環次數
}
for (i=N; i < strlen(str); i++)
{
printf("%c",str[i]);
}
for (i =0; i < N; i++)
{
printf("%c",str[i]);
}
return 0;
}
解法二:
#include<stdio.h>
int main()
{
char a[100],b[100];
int n,i,j;
scanf("%c",&a[0]);
i=0;
while(a[i]!='\n'){
i++;
scanf("%c",&a[i]);
}
scanf("%d",&n);
for(j=0;j<i;j++){
printf("%c",a[(j+n)%i]);
}
}
程序提交成功截圖