1238 - Combinador
Como todo problema de string, para esse precisamos também de calma e paciência... Baot! osre
Descrição
Solução
O jeito mais fácil de resolver esse problema é arrumar um for para colocar duas letras por vez e depois pegar a string que sobrou e colocar ela toda. A ideia é simples, se temos duas strings, uma de tamanho 14 e outra de tamanho 10, então vamos fazer um for até 10 e depois pegar os 4 caracteres faltando da string maior.
#include <string.h>
#include <stdio.h>
int main(){
int N, p, tam;
char A[51], B[51], resposta[102];
scanf("%d\n", &N);
for(int i = 0; i < N; ++i){
scanf("%s %s\n", &A, &B);
memset(resposta, '\0', sizeof(resposta));
tam = strlen(A) < strlen(B) ? strlen(A) : strlen(B);
p = 0;
for(int j = 0; j < tam; ++j){
resposta[p++] = A[j];
resposta[p++] = B[j];
}
if(tam < strlen(A)){
for(int j = tam; j < strlen(A); ++j){
resposta[p++] = A[j];
}
}
if(tam < strlen(B)){
for(int j = tam; j < strlen(B); ++j){
resposta[p++] = B[j];
}
}
printf("%s\n", resposta);
}
return 0;
}#include <iostream>
using namespace std;
int main(){
int N, tam;
string A, B, resposta;
cin >> N;
for(int i = 0; i < N; ++i){
cin >> A >> B;
resposta = "";
tam = A.length() < B.length() ? A.length() : B.length();
for(int j = 0; j < tam; ++j){
resposta += A[j], resposta += B[j];
}
if(A.length() > 0) resposta += A.substr(tam);
if(B.length() > 0) resposta += B.substr(tam);
cout << resposta << endl;
}
return 0;
}var input = require('fs').readFileSync('/dev/stdin', 'utf8');
var lines = input.split('\n');
let N = parseInt(lines.shift());
for(let i = 0; i < N; ++i){
let [A, B] = lines.shift().trim().split(' ');
let tam = Math.min(A.length, B.length);
let resposta = '';
for(let j = 0; j < tam; ++j){
resposta += A[j] + B[j];
}
resposta += (A.length > tam) ? A.substring(tam) : B.substring(tam);
console.log(resposta);
}N = int(input())
for _ in range(N):
A, B = input().strip().split(' ')
tam = min(len(A), len(B))
resposta = ''.join([A[i] + B[i] for i in range(tam)])
resposta = resposta + (A[tam:] if tam < len(A) else B[tam:])
print(resposta)Last updated
Was this helpful?