Coding
  • Welcome
  • Baisc Knowledge
    • Vim
    • C
      • Library
    • Java
      • Setup
      • Java Basic
  • Kattis
    • Easy
      • A Second Opinion
      • A Shortcut to What?
      • A Stack of Gold
      • ACM Contest Scoring
      • ASCII kassi
      • Aaah!
      • Add Two Numbers
      • Adding Trouble
      • Afjörmun
      • Airfare Grants
      • Above Average
      • Akcija
      • Alphabet Spam
      • Amerískur vinnustaður
      • Anti-Palindrome
      • Apaxiaaaaaaaaaaaans!
      • Arithmetic Functions
      • Arm Coordination
      • Arrangement
      • Attendance
      • Autori
      • Average Character
      • Avion
      • Baby Bites
      • Babylonian Numbers
      • ABC
      • Aldur
      • Backspace
      • Bannorð
      • Barcelona
      • Basketball One-on-One
      • Batter Up
      • Beavergnaw
      • Bela
      • BergMál
      • Bergur*
      • Akureyri*
      • Best Compromise
      • Best Relay Team*
      • Besta gjöfin
      • Betting
      • Bijele
      • Bilað Lyklaborð
      • Bitte ein Bit
      • Blandað Best
      • Blaðra
      • Blaðra2
      • Bluetooth*
      • Booking a Room
      • Bottle Opening
      • Bounding Robots
      • Breaking Branches*
      • Bracket Matching*
      • Broken Swords
      • Building Pyramids
      • Bus
      • Bus Assignment
      • CPR Number
      • Call for Problems
      • Canadians, eh?
      • Candy Store
      • Cetiri
      • Cetvrta
      • Champernowne Verification
      • Chanukah Challenge
      • Chardonnay
      • Chocolate Division*
      • Chugging
      • Cinema Crowds 2
      • Class Field Trip
      • ASCII Kassi 2
      • Coffee Cup Combo
      • Cold-puter Science
      • Composed Rhythms
      • Cookies
      • Cooking Water
      • Cornhusker
      • Cosmic Path Optimization
      • Count the Vowels
Powered by GitBook
On this page
  • Question
  • Solution
  • Idea
  • Code
Edit on GitHub
  1. Kattis
  2. Easy

Champernowne Verification

PreviousCetvrtaNextChanukah Challenge

Last updated 5 months ago

Question

Solution

Idea

Instead of taking the input as an integer, I take it as a string. So, this problem becomes a basic string manipulation problem.

  1. The first 9 possible digits is easy to validate

Code

To validate the 10th digit, you can utilise the strcmp() from the C Standard Libaray.

https://open.kattis.com/problems/champernowneverificationopen.kattis.com
string.h
https://github.com/mendax1234/Coding-Problems/blob/main/kattis/champernowneverification/champernowneverification.c
#include <stdio.h>
#include <string.h>
#include <stdbool.h>

#define MAX_LEN 12
#define TEN "10"

int main()
{
  char line[MAX_LEN];
  if (fgets(line, MAX_LEN, stdin))
  {
    line[strcspn(line, "\n")] = 0;
  }
  // Check if it satisfies
  bool is_champ = true;
  int index = 0;
  for (int i = 0; line[i] != 0 && i < 10; i += 1)
  {
    index = i + 1;
    if (i != 9 && line[i] != '1' + i)
    {
      is_champ = false;
      break;
    }
    if (i == 9 && strcmp(line + i, TEN) != 0)
    {
      is_champ = false;
      break;
    }
  }
  is_champ ? printf("%d\n", index) : printf("-1\n");
}