模拟链表

题目:

代码:

#include<stdio.h>
int main()
{
    int a[101],right[101],i,n,t,len;
    scanf("%d",&n);
    for(i=1;i<=n;i++)
    scanf("%d",&a[i]);
    len=n;
    for(i=1;i<=n;i++)//记录a[i]右边的数的下标 
    {
        if(i!=n)
        right[i]=i+1;
        else
        right[i]=0;
    }
    len++;
    scanf("%d",&a[len]);//读入后插进的数 
    t=1;
    while(t!=0)
    {
        if(a[right[t]]>a[len])
        {
            right[len]=right[t]; 
            right[t]=len;
            break;
        }
        t=right[t];
    }
    t=1;
    while(t!=0)
    {
        printf("%d ",a[t]);
        t=right[t];
    }
    getchar();getchar();
    return 0;
} 

运行结果:

题目:

代码:

#include<stdio.h>
int main()
{
  int a[10],book[10],i,sum,total=0; 
  for(a[1]=1;a[1]<=9;a[1]++)
  for(a[2]=1;a[2]<=9;a[2]++)
  for(a[3]=1;a[3]<=9;a[3]++)
  for(a[4]=1;a[4]<=9;a[4]++)
  for(a[5]=1;a[5]<=9;a[5]++)
  for(a[6]=1;a[6]<=9;a[6]++)
  for(a[7]=1;a[7]<=9;a[7]++)
  for(a[8]=1;a[8]<=9;a[8]++)
  for(a[9]=1;a[9]<=9;a[9]++)
  {
    for(i=1;i<=9;i++)
    {
     book[i]=0; 
    }
    for(i=1;i<=9;i++)//标记已经出现的数字 
    {
        book[a[i]]=1;
    }
    sum=0;//记录不同的数字出现的个数 
    for(i=1;i<=9;i++)
    {
        sum=sum+book[i];
    }
    if(sum==9&&a[1]*100+a[2]*10+a[3]+a[4]*100+a[5]*10+a[6]==a[7]*100+a[8]*10+a[9])//已经出现9个不同的数字 
    {
        total++;
        printf("%d%d%d+%d%d%d=%d%d%d\n",a[1],a[2],a[3],a[4],a[5],a[6],a[7],a[8],a[9]);
    }
  }
  printf("total=%d",total/2);//173+286=459与286+173=459一样 
  getchar();getchar();
  return 0;
} 

猜你喜欢

转载自www.cnblogs.com/2719610441qqcom/p/9032941.html