我实际上正在为学校做一项练习,我在 for 循环方面遇到了一些麻烦。练习如下:我必须执行一个函数,将数组的每个数字向右移动(decalageDroite)和一个另一种将每个数字向左移动(decalageGauche)。函数 decalageGauche 工作正常,但是当我尝试使用 decalageDroite 时,它对数组没有任何作用。我尝试将 printf 放入循环中,但它也不起作用。我觉得它永远不会进入循环,我不明白为什么?你能帮我一下吗?
#include <stdio.h>
#include <stdlib.h>
void decalageGauche(int tab[],int n)
{
int v0=tab[0];
int i;
for (i=1 ; i<n ; i++){
tab[i-1]=tab[i];
}
tab[n-1]=v0;
}
void decalageDroite(int tab[],int n){
int i,vt;
vt=tab[n-1];
for (i=n-2 ; i<1 ; i--){
printf("%d ",i);
tab[i]=tab[i+1];
}
}
void afficheTab(int tab[],int n){
int i;
for (i=0 ; i<n ; i++){
printf("%d ",tab[i]);
}
}
int main()
{
int tab[5]= {3,4,-1,12,5};
decalageDroite(tab,5);
afficheTab(tab,5);
return 0;
}
最佳答案
您几乎就拥有它了,只需进行一些小的调整:
void decalageDroite(int tab[], int n) {
int i, vt;
vt = tab[n - 1];
for (i = n - 2; i >= 0; i--) {
//printf("%d ", i);
tab[i + 1] = tab[i];
}
tab[0] = vt;
}
循环需要一直倒计时,直到处理完第一个元素 i >= 0
并且需要将元素向右移动,“a droite”,因此元素 i
被移动到元素 i + 1
。
最后,将 tab[0]
设置为循环之前保存的结束元素。
关于c - 我在 C 中的 for 循环中遇到了麻烦,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49372638/