C语言:有n个整数,使前面各数顺序向后移m个位置,最后m个数变成前面m个数.写一函数实现
我写了程序 语法没有错误 但是没有办法把最后m个数变成前面m个数.以后长期定向提问
#include
int *p,n,m,a[100];
void swap(int *p,int n,int m)
{
int i,j,*t,b[100];
\x05t=b;
\x05for(j=n-1;j>=m;j--)
\x05{
\x05 *(t+j)=*(p+j);
\x05 }
for(i=m-1;i>=0;i--)
\x05 {
\x05\x05*(p+i+m)=*(p+i);
}
\x05for(j=n-1;j>=m;j--)
\x05{
\x05 *(p+j+m)=*(t+j);
\x05}
}\x05
int main()
{
\x05int i;
\x05printf("输入数据的个数以及想要从哪里开始移动:\n");
scanf("%d%d",&n,&m);
printf("输入移动前的数组为:\n");
for(i=0;i
人气:493 ℃ 时间:2019-11-02 02:46:17
解答
void swap(int *p,int n,int m)
{
\x05int i,j,*t,b[100];
\x05t=b;
\x05for(i=0;i=m;i--)
\x05{
\x05\x05p[i] = p[i-m];
\x05}
\x05for(i=0;i不是指针就错,而是你的算法有问题你的代码等价于 void swap(int *p, int n, int m) { int i,j,*t,b[100];t=b;for(j=n-1;j>=m;j--) {b[j]=p[j]; // 把m到n-1复制到b }for(i=m-1;i>=0;i--){ p[i+m]=p[i]; // 把前面m个往后面挪 }for(j=n-1;j>=m;j--){ p[j+m]=b[j]; // 这行在j=n-1的时候,p[j+m]已经越界了 } }
推荐
猜你喜欢
- 往硝酸铜溶液中加入一定量的铁粉,充分反应后,有金属析出,过滤.洗涤后往滤渣中加入稀盐酸,
- The best time to visit Beijing is in (autumn).(对加括号部分提问)
- 试证明:不论m为何值,方程x²/4+(m+1)x+3m-1=0总有两个不相等的实数根.
- 一个教室长8米,宽6米,5米,现4在要粉刷教室的墙和天花板,门窗和黑板的面积是22平方米,平均每平方米用涂
- What is the best title of this passage什么意思
- 小学五年级语文下册的暑假作业的第36页的《图书广告知多少》中的问题.
- 将军百战死 壮士十年归 表达了什么内容
- 大于2的两个质数的乘积一定是( ).(1):质数 (2):偶数 (3):奇数