| Task: | Merkkijonot |
| Sender: | Aapeli |
| Submission time: | 2019-10-13 16:17:56 +0300 |
| Language: | C++ (C++17) |
| Status: | READY |
| Result: | 0 |
| group | verdict | score |
|---|---|---|
| #1 | WRONG ANSWER | 0 |
| #2 | WRONG ANSWER | 0 |
| #3 | WRONG ANSWER | 0 |
| test | verdict | time | group | |
|---|---|---|---|---|
| #1 | WRONG ANSWER | 0.00 s | 1, 2, 3 | details |
| #2 | WRONG ANSWER | 0.04 s | 2, 3 | details |
| #3 | TIME LIMIT EXCEEDED | -- | 3 | details |
| #4 | WRONG ANSWER | 0.07 s | 3 | details |
| #5 | WRONG ANSWER | 0.03 s | 3 | details |
| #6 | ACCEPTED | 0.01 s | 1, 2, 3 | details |
| #7 | ACCEPTED | 0.01 s | 1, 2, 3 | details |
| #8 | WRONG ANSWER | 0.01 s | 1, 2, 3 | details |
| #9 | ACCEPTED | 0.01 s | 1, 2, 3 | details |
| #10 | WRONG ANSWER | 0.01 s | 2, 3 | details |
| #11 | WRONG ANSWER | 0.01 s | 2, 3 | details |
| #12 | WRONG ANSWER | 0.01 s | 2, 3 | details |
| #13 | WRONG ANSWER | 0.01 s | 2, 3 | details |
| #14 | WRONG ANSWER | 0.01 s | 2, 3 | details |
| #15 | WRONG ANSWER | 0.10 s | 3 | details |
| #16 | WRONG ANSWER | 0.08 s | 3 | details |
| #17 | WRONG ANSWER | 0.07 s | 3 | details |
| #18 | WRONG ANSWER | 0.07 s | 3 | details |
| #19 | WRONG ANSWER | 0.07 s | 3 | details |
| #20 | WRONG ANSWER | 0.00 s | 1, 2, 3 | details |
| #21 | WRONG ANSWER | 0.01 s | 1, 2, 3 | details |
| #22 | WRONG ANSWER | 0.01 s | 1, 2, 3 | details |
| #23 | WRONG ANSWER | 0.00 s | 1, 2, 3 | details |
| #24 | WRONG ANSWER | 0.00 s | 1, 2, 3 | details |
Compiler report
input/code.cpp: In function 'int* muutanumeroiksi(char*)':
input/code.cpp:23:19: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for (int i=0;i<strlen(sana); i++){
~^~~~~~~~~~~~~
input/code.cpp:27:28: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int a=i+1;a<strlen(sana2);a++){
~^~~~~~~~~~~~~~
input/code.cpp: In function 'int main()':
input/code.cpp:149:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf("%i",&maara);
~~~~~^~~~~~~~~~~~~
input/code.cpp:160:14: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf("%s",read);
~~~~~^~~~~~~~~~~Code
//
// main.c
// datatahti
//
// Created by aapo haavisto on 10/11/19.
// Copyright © 2019 Aapo Haavisto. All rights reserved.
//
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/*struct x{
int* lista;
int pituus;
};*/
int * muutanumeroiksi(char* sana){
int* lista=(int*)malloc((strlen(sana)+1)*sizeof(int));
char* sana2=(char*)malloc((strlen(sana)+1)*sizeof(char));
strcpy(sana2, sana);
for (int i=0;i<strlen(sana); i++){
if(sana2[i]!=0){
lista[i]=i;
for(int a=i+1;a<strlen(sana2);a++){
if (sana2[a]==sana2[i]){
lista[a]=i;
sana2[a]=0;
}
}
}
//printf("%i",lista[i]);
}
free(sana2);
lista[strlen(sana)]=-1;
return lista;
}
/*struct x etsisamat(char* sana,char merkki){
struct x palautettava;
palautettava.lista=(int*)malloc(51*sizeof(int));
palautettava.pituus=0;
for (int i=0; i<strlen(sana); i++) {
if (sana[i]==merkki){
palautettava.lista[palautettava.pituus]=i;
palautettava.pituus++;
}
}
return palautettava;
}
int onkoharmoniset(char* a,char* b){
if (strlen(a)!=strlen(b))
return 0;
char* c=a;
char* d=b;
for (int i=0; i<strlen(a); i++){
struct x cee=etsisamat(c, c[i]);
struct x dee=etsisamat(d, d[i]);
if(c[i]!=0){
if (memcmp(cee.lista, dee.lista, cee.pituus*sizeof(int))) {
return 0;
}
}
}
return 1;
}
int main(void){
int maara;
scanf("%i",&maara);
int parit=0;
char** kokolista=(char**)malloc(maara*sizeof(char*));
//luetaan merkkijonot
for (int i=0; i<maara; i++){
kokolista[i]=(char*)malloc(51*sizeof(char));
scanf("%s",kokolista[i]);
}
for (int i= 0; i<maara; i++) {
for (int a=i+1; a<maara; a++) {
//if (((kokolista[i][0]!=kokolista[i][1])&&(kokolista[a][0]!=kokolista[a][1]))||((kokolista[i][0]==kokolista[i][1])&&(kokolista[a][0]==kokolista[a][1]))) {
if(strlen(kokolista[i])==strlen(kokolista[a])){
if (onkoharmoniset(kokolista[i], kokolista[a])){
parit++;
}
}
//}
}
printf("%i",parit);
for (int i=0; i<maara; i++)
free(kokolista[i]);
free(kokolista);
}*/
int onkosama(int* a,int* b){
/*if((a[1]==-1)&&(b[1]==-1)){
if (a[0]!=b[0])
return 0;
}*/
int nyt=0;
while(a[nyt]!=-1){
if(b[nyt==-1])
return 1;
if(a[nyt]!=b[nyt])
return 0;
nyt++;
}
return 1;
}
int main(void){
//test onkosama
/*int* test=malloc(5*sizeof(int));
test[0]=0;
test[1]=0;
test[2]=2;
test[3]=3;
test[4]=-1;
printf("%i",onkosama(test, test));*/
/*char* moi=malloc(7*sizeof(char));
moi="abcdef";
int* oo=muutanumeroiksi(moi);
for (int i=0; i<7; i++) {
printf("%i o",oo[i]);
}*/
int maara;
scanf("%i",&maara);
int parit=0;
int** numerolista=(int**)malloc(maara*sizeof(int*));
//luetaan merkkijonot
for (int i=0; i<maara; i++){
char* read=(char*)malloc(51*sizeof(char));
numerolista[i]=(int*)malloc(51*sizeof(int));
//printf("testi");
scanf("%s",read);
numerolista[i]=muutanumeroiksi(read);
free(read);
}
for (int i=0; i<maara-1; i++) {
int loytyi=0;
if (numerolista[i][0]!=-1) {
for (int a=i+1; a<maara; a++) {
if (onkosama(numerolista[i], numerolista[a])){
loytyi++;
numerolista[a][0]=-1;
}
}
}
//printf("loytyi %i ",loytyi);
if (loytyi>0)
parit=parit+((loytyi+1)*loytyi)/2;
//printf("parit %i ",parit);
}
for (int i=0; i<maara; i++){
free(numerolista[i]);
}
free(numerolista);
printf("%i\n",parit);
}
Test details
Test 1
Group: 1, 2, 3
Verdict: WRONG ANSWER
| input |
|---|
| 20 FFDISOVJLPIASANJRBHQXJVW HBGVRZFWOTAAVUPYKMKXAOBEYUE JKHXTPHUKTLTLNXMXMSYYFLF HCSZMXTZCUFHIHSTEWKHCFZRTXU ... |
| correct output |
|---|
| 20 |
| user output |
|---|
| 106 |
Test 2
Group: 2, 3
Verdict: WRONG ANSWER
| input |
|---|
| 5000 AJEDROEDXRGDUSDAPZBXXQBPJ PDGCTAGCRTBCJICPFELRRMLFD TISAOTGMDKUCITIEFQVCSBZJYUUO FMASVJYFPMELSVLQWFZVLVMSPHYL ... |
| correct output |
|---|
| 2178556 |
| user output |
|---|
| -1198547071 |
Test 3
Group: 3
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 100000 RESKYADLVRSDCDXJVECAJCAP CZLIWDHKVNRJHZINHFBOQEPN LSTRSDTLADUIWXFQJSQPVRSPBCTZ QEMSZOQSSVBRNQTCLJQIGVQO ... |
| correct output |
|---|
| 404880850 |
| user output |
|---|
| (empty) |
Test 4
Group: 3
Verdict: WRONG ANSWER
| input |
|---|
| 100000 AAAAAAAAAAAAAAAAAAAAAAAAAAAAAA... |
| correct output |
|---|
| 4999950000 |
| user output |
|---|
| 704982704 |
Test 5
Group: 3
Verdict: WRONG ANSWER
| input |
|---|
| 100000 IPI Q SPGV UNYE ... |
| correct output |
|---|
| 1041990627 |
| user output |
|---|
| 706556240 |
Test 6
Group: 1, 2, 3
Verdict: ACCEPTED
| input |
|---|
| 20 A B C D ... |
| correct output |
|---|
| 190 |
| user output |
|---|
| 190 |
Test 7
Group: 1, 2, 3
Verdict: ACCEPTED
| input |
|---|
| 1 A |
| correct output |
|---|
| 0 |
| user output |
|---|
| 0 |
Test 8
Group: 1, 2, 3
Verdict: WRONG ANSWER
| input |
|---|
| 20 A BB CCC DDDD ... |
| correct output |
|---|
| 0 |
| user output |
|---|
| 190 |
Test 9
Group: 1, 2, 3
Verdict: ACCEPTED
| input |
|---|
| 2 A A |
| correct output |
|---|
| 1 |
| user output |
|---|
| 1 |
Test 10
Group: 2, 3
Verdict: WRONG ANSWER
| input |
|---|
| 5000 SEKNHNRHSRFYIHSCDPGXPTGUSYBFKZ... |
| correct output |
|---|
| 20861 |
| user output |
|---|
| 31228275 |
Test 11
Group: 2, 3
Verdict: WRONG ANSWER
| input |
|---|
| 5000 UGPWHWOWAREEIROZTRJGUCKDKTZJEO... |
| correct output |
|---|
| 22818 |
| user output |
|---|
| 32379091 |
Test 12
Group: 2, 3
Verdict: WRONG ANSWER
| input |
|---|
| 5000 FFQQCBCINBDWIKHFPO SCJU DNHYPGIQNZS KNQCYRAXHHKORXMOVHL ... |
| correct output |
|---|
| 22268 |
| user output |
|---|
| 31395985 |
Test 13
Group: 2, 3
Verdict: WRONG ANSWER
| input |
|---|
| 5000 QVWMSYPWXWBBXWCVEOUAVQLDWNBXZB... |
| correct output |
|---|
| 22589 |
| user output |
|---|
| 67740156 |
Test 14
Group: 2, 3
Verdict: WRONG ANSWER
| input |
|---|
| 5000 JYORMNQAKXHNRBWGGSMWXWXMBKPBZU... |
| correct output |
|---|
| 20482 |
| user output |
|---|
| 26436654 |
Test 15
Group: 3
Verdict: WRONG ANSWER
| input |
|---|
| 100000 DCXXVIEYQAASZJYUUVYZUIJFGVBAYC... |
| correct output |
|---|
| 8925377 |
| user output |
|---|
| 1865827058 |
Test 16
Group: 3
Verdict: WRONG ANSWER
| input |
|---|
| 100000 IJZHBIYNWQBDWNGZWVXJKXXWFVLPQX... |
| correct output |
|---|
| 8907840 |
| user output |
|---|
| 1340321203 |
Test 17
Group: 3
Verdict: WRONG ANSWER
| input |
|---|
| 100000 GWUGLGQDAYGGJROIAKBMMICQMDUQQQ... |
| correct output |
|---|
| 8771809 |
| user output |
|---|
| -293122805 |
Test 18
Group: 3
Verdict: WRONG ANSWER
| input |
|---|
| 100000 SWVSVXURRSLCSHCPAKWESIPCNDKYLD... |
| correct output |
|---|
| 8704480 |
| user output |
|---|
| 1285251251 |
Test 19
Group: 3
Verdict: WRONG ANSWER
| input |
|---|
| 100000 ZLSNSZBGIMCOLPDEAKVDAJCTMBNRLH... |
| correct output |
|---|
| 8672362 |
| user output |
|---|
| 285285709 |
Test 20
Group: 1, 2, 3
Verdict: WRONG ANSWER
| input |
|---|
| 20 AAB D CDBAA D ... |
| correct output |
|---|
| 15 |
| user output |
|---|
| 172 |
Test 21
Group: 1, 2, 3
Verdict: WRONG ANSWER
| input |
|---|
| 20 A CDD AABBC DBCB ... |
| correct output |
|---|
| 15 |
| user output |
|---|
| 190 |
Test 22
Group: 1, 2, 3
Verdict: WRONG ANSWER
| input |
|---|
| 20 ACADD CDDCD DACA CCDCA ... |
| correct output |
|---|
| 17 |
| user output |
|---|
| 123 |
Test 23
Group: 1, 2, 3
Verdict: WRONG ANSWER
| input |
|---|
| 20 DCDA BDBA CACBD BA ... |
| correct output |
|---|
| 7 |
| user output |
|---|
| 213 |
Test 24
Group: 1, 2, 3
Verdict: WRONG ANSWER
| input |
|---|
| 20 DDA BBCDC DDD CCD ... |
| correct output |
|---|
| 14 |
| user output |
|---|
| 141 |
