指针-数的互逆

简介: 指针-数的互逆

任务描述

定义一个数的逆如下:两个数互为逆,当且仅当它们的绝对值位数相同且各位对应数字之和为 9。例如:11 和 −88 互为逆,999 和 000 互为逆,但 999 和 0 不互为逆。


现在给出多组数对,请编程判断每对数是否互为逆。如果是,请输出它们的和;如果不是,请输出“illegal operation”。


相关知识

参考之前的关卡。


编程要求

根据提示,在右侧编辑器的Begin-End区域内补充代码。


测试说明

输入:第一行为数据组数 T,T∈[1,100];接下来 T 行,每行 2 个数 a 和 b (∣a∣,∣b∣∈[0,10100]),以一个空格分隔。a,b 可能有前导 0 ,仅负数带符号。


输出:对于每组数据,如果 a 和 b 互为逆,输出它们的和 (无前导 0,仅负数有符号);否则输出“illegal operation”。


例如测试集 1 的输入是: 5 01 98 -100 899 233 332 00000000000001 -99999999999998 -45454 54545


测试集 1 的运行结果为: 99 799 illegal operation -99999999999997 9091

#include <stdio.h>
#include <string.h>
char result[1000];
char *sub(char *a, char *b)
{
  int c=0,n;
    while(*(a+c)!='\0')
    c++;
    c--;
    n=c;
    for(;c>=0;c--)
    {
        if(*(a+c)-*(b+c)>=0)
        {
            result[c]=*(a+c)-*(b+c)+'0';
        }
        else if(*(a+c)-*(b+c)<0)
        {
            *(a+c-1)=*(a+c-1)-'1'+'0';
            result[c]=*(a+c)-*(b+c)+'9'-'0'+'1';
        }
    }
    while(result[0]=='0')
    {
        for(c=0;c<=n;c++)
        result[c]=result[c+1];
        result[n]='\0';
        n--;
    }
    return(result);
}
int main()
{
  char sa[1000], sb[1000];
  char *a, *b;
  int signa, signb;
  int i, t, la, lb;
  scanf("%d", &t);
  while (t--)
  {
    scanf("%s%s", sa, sb);
    a = (sa[0] == '-') ? sa + 1 : sa;
    b = (sb[0] == '-') ? sb + 1 : sb;
    signa = (sa[0] == '-') ? 1 : 0;
    signb = (sb[0] == '-') ? 1 : 0;
    la = strlen(a);
    lb = strlen(b);
    if (la != lb)
      printf("illegal operation\n");
    else
    {
      int flag = 1;
      for (i = 0; i < la; i++)
      {
        if (a[i] + b[i] - '0' - '0' != 9)
        {
          printf("illegal operation\n");
          flag = 0;
          break;
        }
      }
      if (flag == 0)
      {
        continue;
      }
      if (signa == 1 && signb == 1)
      {
        printf("-");
        for (i = 0; i < la; i++)
          printf("9");
        printf("\n");
      }
      else if (signa == 0 && signb == 0)
      {
        for (i = 0; i < la; i++)
          printf("9");
        printf("\n");
      }
      else if (signa == 0 && signb == 1)
      {
        if (strcmp(a, b) >= 0)
          printf("%s\n", sub(a, b));
        else
          printf("-%s\n", sub(b, a));
      }
      else
      {
        if (strcmp(b, a) >= 0)
          printf("%s\n", sub(b, a));
        else
          printf("-%s\n", sub(a, b));
      }
    }
  }
} 



相关文章
|
C语言
C 语言实例 - 判断三个数中的最大数
C 语言实例 - 判断三个数中的最大数。
162 36
【Leetcode -1171.从链表中删去总和值为零的连续节点 -1669.合并两个链表】
【Leetcode -1171.从链表中删去总和值为零的连续节点 -1669.合并两个链表】
106 0
交换两个数的值的方法(三种)
交换两个数的值的方法(三种)
73 1
不使用第三变量。如何对2个数进行交换
不使用第三变量。如何对2个数进行交换
85 0
|
Cloud Native Go
927. 三等分:计数和三指针
这是 力扣上的 927. 三等分,难度为 困难。
内存的清道夫——函数的尾调用
尾调用是什么,它能解决什么问题,他的存在意味着什么,为什么我叫他内存的清道夫,下面我将带读者通过概念,作用,尾巴递归三个方面来学习使用函数的尾调用。
85 0
|
前端开发 JavaScript
|
存储 C语言
【C 语言】二级指针作为输入 ( 自定义二级指针内存 | 二级指针排序 | 通过 交换指针指向的内存数据 方式进行排序 )
【C 语言】二级指针作为输入 ( 自定义二级指针内存 | 二级指针排序 | 通过 交换指针指向的内存数据 方式进行排序 )
122 0
【C 语言】二级指针作为输入 ( 自定义二级指针内存 | 二级指针排序 | 通过 交换指针指向的内存数据 方式进行排序 )
|
Java
指针碰撞和空闲列表
指针碰撞和空闲列表
535 0
|
存储 C语言
【C 语言】指针数据类型 ( 指针类型变量 与 指针指向的内存块 概念区别 | 指针赋值 | 指针运算 | 内存赋值 | 内存取值 | 内存修改注意事项 )
【C 语言】指针数据类型 ( 指针类型变量 与 指针指向的内存块 概念区别 | 指针赋值 | 指针运算 | 内存赋值 | 内存取值 | 内存修改注意事项 )
181 0