Task: | Merkkijonot |
Sender: | Aapeli |
Submission time: | 2019-10-13 16:05:12 +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 | ACCEPTED | 0.00 s | 1, 2, 3 | details |
#2 | WRONG ANSWER | 0.05 s | 2, 3 | details |
#3 | TIME LIMIT EXCEEDED | -- | 3 | details |
#4 | WRONG ANSWER | 0.07 s | 3 | details |
#5 | TIME LIMIT EXCEEDED | -- | 3 | details |
#6 | WRONG ANSWER | 0.01 s | 1, 2, 3 | details |
#7 | ACCEPTED | 0.00 s | 1, 2, 3 | details |
#8 | ACCEPTED | 0.01 s | 1, 2, 3 | details |
#9 | WRONG ANSWER | 0.00 s | 1, 2, 3 | details |
#10 | WRONG ANSWER | 0.16 s | 2, 3 | details |
#11 | WRONG ANSWER | 0.16 s | 2, 3 | details |
#12 | WRONG ANSWER | 0.16 s | 2, 3 | details |
#13 | WRONG ANSWER | 0.16 s | 2, 3 | details |
#14 | WRONG ANSWER | 0.16 s | 2, 3 | details |
#15 | TIME LIMIT EXCEEDED | -- | 3 | details |
#16 | TIME LIMIT EXCEEDED | -- | 3 | details |
#17 | TIME LIMIT EXCEEDED | -- | 3 | details |
#18 | TIME LIMIT EXCEEDED | -- | 3 | details |
#19 | TIME LIMIT EXCEEDED | -- | 3 | details |
#20 | WRONG ANSWER | 0.01 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.01 s | 1, 2, 3 | details |
#24 | WRONG ANSWER | 0.01 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:145:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf("%i",&maara); ~~~~~^~~~~~~~~~~~~ input/code.cpp:156: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 merkkijonotfor (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)return 0;int nyt=0;while(a[nyt]!=-1){if(a[nyt]!=b[nyt])return 0;nyt++;}if(b[nyt]==-1)return 1;elsereturn 0;}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 merkkijonotfor (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: ACCEPTED
input |
---|
20 FFDISOVJLPIASANJRBHQXJVW HBGVRZFWOTAAVUPYKMKXAOBEYUE JKHXTPHUKTLTLNXMXMSYYFLF HCSZMXTZCUFHIHSTEWKHCFZRTXU ... |
correct output |
---|
20 |
user output |
---|
20 |
Test 2
Group: 2, 3
Verdict: WRONG ANSWER
input |
---|
5000 AJEDROEDXRGDUSDAPZBXXQBPJ PDGCTAGCRTBCJICPFELRRMLFD TISAOTGMDKUCITIEFQVCSBZJYUUO FMASVJYFPMELSVLQWFZVLVMSPHYL ... |
correct output |
---|
2178556 |
user output |
---|
2217212 |
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: TIME LIMIT EXCEEDED
input |
---|
100000 IPI Q SPGV UNYE ... |
correct output |
---|
1041990627 |
user output |
---|
(empty) |
Test 6
Group: 1, 2, 3
Verdict: WRONG ANSWER
input |
---|
20 A B C D ... |
correct output |
---|
190 |
user output |
---|
0 |
Test 7
Group: 1, 2, 3
Verdict: ACCEPTED
input |
---|
1 A |
correct output |
---|
0 |
user output |
---|
0 |
Test 8
Group: 1, 2, 3
Verdict: ACCEPTED
input |
---|
20 A BB CCC DDDD ... |
correct output |
---|
0 |
user output |
---|
0 |
Test 9
Group: 1, 2, 3
Verdict: WRONG ANSWER
input |
---|
2 A A |
correct output |
---|
1 |
user output |
---|
0 |
Test 10
Group: 2, 3
Verdict: WRONG ANSWER
input |
---|
5000 SEKNHNRHSRFYIHSCDPGXPTGUSYBFKZ... |
correct output |
---|
20861 |
user output |
---|
16622 |
Test 11
Group: 2, 3
Verdict: WRONG ANSWER
input |
---|
5000 UGPWHWOWAREEIROZTRJGUCKDKTZJEO... |
correct output |
---|
22818 |
user output |
---|
18840 |
Test 12
Group: 2, 3
Verdict: WRONG ANSWER
input |
---|
5000 FFQQCBCINBDWIKHFPO SCJU DNHYPGIQNZS KNQCYRAXHHKORXMOVHL ... |
correct output |
---|
22268 |
user output |
---|
18514 |
Test 13
Group: 2, 3
Verdict: WRONG ANSWER
input |
---|
5000 QVWMSYPWXWBBXWCVEOUAVQLDWNBXZB... |
correct output |
---|
22589 |
user output |
---|
19224 |
Test 14
Group: 2, 3
Verdict: WRONG ANSWER
input |
---|
5000 JYORMNQAKXHNRBWGGSMWXWXMBKPBZU... |
correct output |
---|
20482 |
user output |
---|
17966 |
Test 15
Group: 3
Verdict: TIME LIMIT EXCEEDED
input |
---|
100000 DCXXVIEYQAASZJYUUVYZUIJFGVBAYC... |
correct output |
---|
8925377 |
user output |
---|
(empty) |
Test 16
Group: 3
Verdict: TIME LIMIT EXCEEDED
input |
---|
100000 IJZHBIYNWQBDWNGZWVXJKXXWFVLPQX... |
correct output |
---|
8907840 |
user output |
---|
(empty) |
Test 17
Group: 3
Verdict: TIME LIMIT EXCEEDED
input |
---|
100000 GWUGLGQDAYGGJROIAKBMMICQMDUQQQ... |
correct output |
---|
8771809 |
user output |
---|
(empty) |
Test 18
Group: 3
Verdict: TIME LIMIT EXCEEDED
input |
---|
100000 SWVSVXURRSLCSHCPAKWESIPCNDKYLD... |
correct output |
---|
8704480 |
user output |
---|
(empty) |
Test 19
Group: 3
Verdict: TIME LIMIT EXCEEDED
input |
---|
100000 ZLSNSZBGIMCOLPDEAKVDAJCTMBNRLH... |
correct output |
---|
8672362 |
user output |
---|
(empty) |
Test 20
Group: 1, 2, 3
Verdict: WRONG ANSWER
input |
---|
20 AAB D CDBAA D ... |
correct output |
---|
15 |
user output |
---|
6 |
Test 21
Group: 1, 2, 3
Verdict: WRONG ANSWER
input |
---|
20 A CDD AABBC DBCB ... |
correct output |
---|
15 |
user output |
---|
6 |
Test 22
Group: 1, 2, 3
Verdict: WRONG ANSWER
input |
---|
20 ACADD CDDCD DACA CCDCA ... |
correct output |
---|
17 |
user output |
---|
6 |
Test 23
Group: 1, 2, 3
Verdict: WRONG ANSWER
input |
---|
20 DCDA BDBA CACBD BA ... |
correct output |
---|
7 |
user output |
---|
13 |
Test 24
Group: 1, 2, 3
Verdict: WRONG ANSWER
input |
---|
20 DDA BBCDC DDD CCD ... |
correct output |
---|
14 |
user output |
---|
18 |