请问这个应该怎么做?原题是第一张,机翻是第二张。请大lao帮我编程一下,蟹蟹。
#include <stdio.h>
#include <stdlib.h>
#define SIZE 10
void slideAndMerge(int *nums);
int main(int argc, char* argv[]) {
int numbers[SIZE];
int i;
i = 0;
while (i < SIZE) {
int number = getchar() - 48;
numbers[i] = number;
i++;
}
i = 0;
while (i < SIZE) {
printf("%d ", numbers[i]);
i++;
}
printf("\n");
slideAndMerge(numbers);
i = 0;
while (i < SIZE) {
printf("%d ", numbers[i]);
i++;
}
printf("\n");
return 0;
}
void slideAndMerge(int *nums) {
// TODO
}
void slideAndMerge(int *nums) {
int i,j;
//第一步先将非0数前移
for(i=0;i<SIZE;i++)
{
if(nums[i] == 0)
{
for(j=i;j<SIZE-1;j++)
nums[j] = nums[j+1];
nums[SIZE-1] = 0;
}
}
//第二步,相邻两个元素比较是否相等,相等则相加合并
for(i=0;i<SIZE-1;i++)
{
if(a[i] == a[i+1])
{
a[i] = a[i]*2;
for(j=i;j<SIZE-1;j++)
nums[j] = nums[j+1];
nums[SIZE-1] = 0;
}
}
}
void slideAndMerge(int *nums) {
int i,j;
int n = SIZE;
//第一步先将非0数前移
for(i=0;i<n;i++)
{
if(nums[i] == 0)
{
for(j=i;j<SIZE-1;j++)
nums[j] = nums[j+1];
nums[SIZE-1] = 0;
i--;
n--;
}
}
//第二步,相邻两个元素比较是否相等,相等则相加合并
n = SIZE;
for(i=0;i<n-1;i++)
{
if(nums[i] == nums[i+1])
{
nums[i] = nums[i]*2;
for(j=i+1;j<SIZE-1;j++)
nums[j] = nums[j+1];
nums[SIZE-1] = 0;
n--;
}
}
}