poj 3589 Number-guessing Game(水题)

本文介绍了一种猜数字游戏的算法实现,通过分析两个四位数的对应位来判断猜得是否正确。具体而言,该算法区分了位置正确的数字(A)和数字正确但位置错误的数字(B)。通过两层循环遍历的方式进行比较,最终输出A和B的数量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

A 表示 猜的位置和数对,B表示猜的数对但是位置不对

问 A,和B各有多少个

读题是关键啊,一开始就把题给理解错了

#include <iostream>
#include <string.h>
using namespace std;
#define maxnum 10
char num1[maxnum],num2[maxnum];
int a[maxnum],b[maxnum];
void fun()
{
 int i;
 for(i=0;i<4;i++)
 {
  a[i]=num1[i]-'0';
  b[i]=num2[i]-'0';
 }
}
int main()
{
 int t,i,j;
 int flag1,flag2;
 cin>>t;
 while(t--)
 {
  cin>>num1>>num2;
  fun();
  flag1=0;
  flag2=0;
  for(i=0;i<4;i++)
   for(j=0;j<4;j++)
   {
    if(a[i]==b[j]&&i!=j)
     flag2++;
    if(a[i]==b[j]&&i==j)
     flag1++;
   }
  cout<<flag1<<"A"<<flag2<<"B"<<endl;
 }
 return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值