C语言整数移位问题
已知整数x,求将其每一位右方向循环移动n位得到的数(右循环移位:总是把右端移出的位填补到左端空出的位)。输入:行1:中输入整数xn;注意:此题每个测试输入有多组测试数据!...
已知整数x,求将其每一位右方向循环移动n位得到的数(右循环移位:总是把右端移出的位填补到左端空出的位)。输入:行1:中输入整数x n;
注意:此题每个测试输入有多组测试数据!
输出:行1:输出位移后的x;
有大神帮们检查我的代码为什么OJ反馈RUN TIME ERR吗?
#include<stdio.h>
#include<string.h>
int main()
{
int x,n,t,i,s,p;
char num0[100],num1[100];
while(scanf("%d%d",&x,&n)!=EOF)
{
sprintf(num0,"%d",x);
sprintf(num1,"%d",x);
for(i=0;i<strlen(num0)-n;i++)
{
num0[i+n]=num1[i];
}
p=strlen(num0)-n;
for(i=0;i<n;i++,p++)
{
num0[i]=num1[p];
}
sscanf(num0,"%d",&s);
printf("%d\n",s);
}
return 0;
} 展开
注意:此题每个测试输入有多组测试数据!
输出:行1:输出位移后的x;
有大神帮们检查我的代码为什么OJ反馈RUN TIME ERR吗?
#include<stdio.h>
#include<string.h>
int main()
{
int x,n,t,i,s,p;
char num0[100],num1[100];
while(scanf("%d%d",&x,&n)!=EOF)
{
sprintf(num0,"%d",x);
sprintf(num1,"%d",x);
for(i=0;i<strlen(num0)-n;i++)
{
num0[i+n]=num1[i];
}
p=strlen(num0)-n;
for(i=0;i<n;i++,p++)
{
num0[i]=num1[p];
}
sscanf(num0,"%d",&s);
printf("%d\n",s);
}
return 0;
} 展开
2个回答
展开全部
当要求的移位数 多于 数的位数时,你的程序有错。
例如 12 5 (应当允许转多个圈)。
给你改了一下,但没有给你改 EOF: (scanf() == EOF 是个达不到的条件)。
输入数是否有最多位数规定,否则直接用字符串读入为好。
========
#include<stdio.h>
#include<string.h>
int main(){
int x,n,i,j,L;
char num[100];
while(scanf("%s %d",&num,&n) !=EOF)
{
L = strlen(num);
for(i=0;i<n;i++)
{
num[99]=num[L-1];
for (j=L-1;j>0;j--) num[j]=num[j-1];
num[0]=num[99];
}
printf("%s\n",num); // 这里给你按字符串形式输出了。你可以转为int 输出,免去左端的0
}
return 0;
}
例如 12 5 (应当允许转多个圈)。
给你改了一下,但没有给你改 EOF: (scanf() == EOF 是个达不到的条件)。
输入数是否有最多位数规定,否则直接用字符串读入为好。
========
#include<stdio.h>
#include<string.h>
int main(){
int x,n,i,j,L;
char num[100];
while(scanf("%s %d",&num,&n) !=EOF)
{
L = strlen(num);
for(i=0;i<n;i++)
{
num[99]=num[L-1];
for (j=L-1;j>0;j--) num[j]=num[j-1];
num[0]=num[99];
}
printf("%s\n",num); // 这里给你按字符串形式输出了。你可以转为int 输出,免去左端的0
}
return 0;
}
展开全部
/*
123456 2
561234
123456789 1
912345678
123456789 2
891234567
^Z
Press any key to continue
*/
#include <stdio.h>
#include <string.h>
int main() {
int x,n,len,i,j;
char num[12],t;
while(scanf("%d%d",&x,&n) != EOF) {
sprintf(num,"%d",x);
len = strlen(num);
for(i = 0;i < n;i++) {
t = num[len - 1];
for(j = len - 1; j > 0; --j)
num[j] = num[j - 1];
num[0] = t;
}
printf("%s\n",num);
}
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询