c程序查找调用函数

标签 c algorithm

两个整数分别存储在数组a 1 和a 2 中,通过与计算相同的过程计算乘积,但没有输出正确的结果。 问题是:想要产生 312*321 = 1 0 0 1 5 2 但第一个程序产生 ? 0 9 9 11 5 2 要产生正确的结果 1 0 0 1 5 2,调用函数名称 func(c,N*2)

#include <stdio.h>
#include <stdlib.h>
#define N 3
int main()
 {

 int a1[N]={1,2,3};
 int a2[N]={2,1,3};
 int b[N][N];
 int c[N*2];
 int i,j;

 for(i=0;i<N;i++){
    for(j=0;j<N;j++)
b[i][j]=a1[j]*a2[i];
 }


 c[0]=b[0][0];
 c[1]=b[0][1]+b[1][0];
 c[2]=b[0][2]+b[1][1]+b[2][0];
 c[3]=b[1][2]+b[2][1];
 c[4]=b[2][2];

 for(i=N*2-1;i>=0;i--)
 {
     printf("%d ",c[i]);
 }
    printf("\n");
    return 0;
}

结果:0 9 9 11 5 2

       |0|1|2| ->A1
  ----------------
A2<-| 0|2|4|6|     
    | 1|1|2|3| 
    | 2|3|6|9|

这个数组和321*312一样,用手在纸上计算

问题:定义函数func()输出正确结果1 0 0 1 5 2,调用func(c,N*2);下面我以粗体形式发布了调用函数 func() 的代码。任何想法?? func() 背后的逻辑是什么?反复试验?这背后有算法吗?

#include <stdio.h>
#include <stdlib.h>
#define N 3
int main()
 {

 int a1[N]={1,2,3};
 int a2[N]={2,1,3};
 int b[N][N];
 int c[N*2];
 int i,j;

 for(i=0;i<N;i++){
    for(j=0;j<N;j++)
b[i][j]=a1[j]*a2[i];
 }


 c[0]=b[0][0];
 c[1]=b[0][1]+b[1][0];
 c[2]=b[0][2]+b[1][1]+b[2][0];
 c[3]=b[1][2]+b[2][1];
 c[4]=b[2][2];

 **func(c,N*2);**

 for(i=N*2-1;i>=0;i--)
 {
     printf("%d ",c[i]);
 }
    printf("\n");
    return 0;
}

**void func(int a[],int digit)
{
   here no idea....
    }**

最佳答案

尝试一下;

void func(int a[], int digit)
{
    int i, c = 0;
    for(i = 0; i < digit; i ++)
    {
        a[i] += c;
        c = a[i] / 10;
        a[i] = a[i] % 10;
    }
}

关于c程序查找调用函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45396581/

相关文章:

c - 反转链表的每 k 个节点

c - 对递归函数的多次调用的控制流程如何?

Python:对体素组件进行网格划分以计算表面积

java - 从十进制度转换为六十进制度

java - 尝试将 Knuth 的 Mastermind 算法应用到我的 Java Mastermind 项目中

c++ - 在 C++ 中使用 BFS 的最短路径

结构成员对齐困惑

c - 每个进程的最大线程数-sysconf(_SC_THREAD_THREADS_MAX)失败

c - 从套接字缓冲区逐行读取

javascript - 两个整数之间的随机整数算法无法按预期工作?